当前位置: 首页 > news >正文

【算法】冒泡排序

目录

一、算法概述

二、算法原理

1. 核心思想

2. 排序过程演示

三、标准实现代码

四、时间复杂度分析

五、优化策略

1. 提前终止优化

2. 记录最后交换位置

六、算法特性

七、实际应用

八、扩展思考

九、总结


一、算法概述

冒泡排序(Bubble Sort)是最经典的排序算法之一,其名称源于元素移动方式如同水中气泡上浮的过程。这个简单直观的算法诞生于1956年,至今仍是计算机科学入门教育的经典案例。

二、算法原理

1. 核心思想

通过相邻元素的比较和交换,使较大元素逐步"浮"到数列末端。每一轮排序将确定一个元素的最终位置,类似于气泡从水底升到水面。

2. 排序过程演示

以数组 [5, 3, 8, 1, 2] 为例:

初始:5 3 8 1 2
第1轮:
3 5 8 1 2 → 比较5和3
3 5 1 8 2 → 比较8和1
3 5 1 2 8 → 比较8和2(确定最大值8)第2轮:
3 1 5 2 8 → 比较5和1
3 1 2 5 8 → 比较5和2(确定次大值5)第3轮:
1 3 2 5 8 → 比较3和1
1 2 3 5 8 → 比较3和2(确定中间值3)第4轮:
1 2 3 5 8 → 比较2和1(完全有序)

三、标准实现代码

def bubble_sort(arr):n = len(arr)for i in range(n):# 每次减少比较范围for j in range(0, n-i-1):if arr[j] > arr[j+1]:arr[j], arr[j+1] = arr[j+1], arr[j]return arr

四、时间复杂度分析

  • 最好情况(已有序):O(n) (优化版)

  • 平均情况:O(n²)

  • 最坏情况(完全逆序):O(n²)

空间复杂度:O(1)(原地排序)

五、优化策略

1. 提前终止优化

def optimized_bubble_sort(arr):n = len(arr)for i in range(n):swapped = Falsefor j in range(0, n-i-1):if arr[j] > arr[j+1]:arr[j], arr[j+1] = arr[j+1], arr[j]swapped = Trueif not swapped:breakreturn arr

2. 记录最后交换位置

def improved_bubble_sort(arr):n = len(arr)last_swap = n - 1while last_swap > 0:new_swap = 0for j in range(last_swap):if arr[j] > arr[j+1]:arr[j], arr[j+1] = arr[j+1], arr[j]new_swap = jlast_swap = new_swapreturn arr

六、算法特性

  • 稳定性:稳定排序(相同元素相对位置不变)

  • 适用场景:

    • 小规模数据排序

    • 教学演示用途

    • 数据基本有序时表现良好

  • 缺点:

    • 大规模数据效率低下

    • 元素移动次数较多

七、实际应用

  1. 硬件资源受限的嵌入式系统

  2. 图形界面中的简单数据排序

  3. 其他排序算法的基准测试对比

  4. 链表数据的排序(相比数组更具优势)

八、扩展思考

  1. 双向冒泡排序(鸡尾酒排序):交替进行正向和反向遍历

  2. 结合插入排序的混合算法

  3. 并行化处理的可能性

九、总结

冒泡排序虽不是最高效的排序算法,但其简明性使其成为:

  • 理解排序思想的绝佳范例

  • 算法优化的典型研究对象

  • 其他高级排序算法的基础参照

在真实开发中,当数据规模超过1000时建议使用更高效的算法(如快速排序、归并排序)。但对于算法学习者,深入理解冒泡排序将有助于建立基础的算法思维模式。

附录:不同语言实现示例

// Java实现
public static void bubbleSort(int[] arr) {boolean swapped;for (int i = 0; i < arr.length-1; i++) {swapped = false;for (int j = 0; j < arr.length-i-1; j++) {if (arr[j] > arr[j+1]) {int temp = arr[j];arr[j] = arr[j+1];arr[j+1] = temp;swapped = true;}}if (!swapped) break;}
}

相关文章:

【算法】冒泡排序

目录 一、算法概述 二、算法原理 1. 核心思想 2. 排序过程演示 三、标准实现代码 四、时间复杂度分析 五、优化策略 1. 提前终止优化 2. 记录最后交换位置 六、算法特性 七、实际应用 八、扩展思考 九、总结 一、算法概述 冒泡排序&#xff08;Bubble Sort&#xff0…...

R Excel 文件:高效数据处理的利器

R Excel 文件:高效数据处理的利器 在数据分析领域,R语言因其强大的统计分析和可视化功能而备受推崇。而R Excel文件,作为R语言与Excel的桥梁,使得数据在R和Excel之间的高效转换成为可能。本文将详细介绍R Excel文件的概念、应用场景以及操作方法。 一、R Excel文件的概念…...

数据库(MySQL):使用命令从零开始在Navicat创建一个数据库及其数据表(一).创建基础表

一. 使用工具和命令 1.1 使用的工具 Navicat Premium 17 &#xff1a;“Navicat”是一套可创建多个连接的数据库管理工具。 MySQL版本8.0.39 。 1.2 使用的命令 Navicat中使用的命令 命令 命令解释 SHOW DATABASES&#xff1b; 展示所有的数据库 CREATE DATABASE 数据…...

电力通信物联网应用,国密网关守护电力数据安全

电力国密网关是用于保护电力调度数据网路由器和电力系统的局域网之间通信安全的电力专用网关机&#xff0c;主要为上下级控制系统之间的广域网通信提供认证与加密服务&#xff0c;实现数据传输的机密性、完整性。 国密算法网关功能特点 身份认证&#xff1a;对接入的设备和用户…...

vue:vite 代理服务器 proxy 配置

Vite 代理服务器&#xff08;Proxy&#xff09;的配置通常用于开发环境&#xff0c;以解决跨域请求等问题。以下是一个详细的配置步骤&#xff1a; 通过以上步骤&#xff0c;你就可以在 Vite 项目中配置代理服务器&#xff0c;以便在开发过程中方便地访问后端服务。 ‌找到 Vi…...

Java【网络原理】(2)初识网络续与网络编程

目录 1.前言 2.正文 2.1TCP协议与UDP协议 2.2socket API进行网络编程 2.2.1DatagramPacket类 2.2.1.1发送数据报 2.2.1.2接收数据报 2.2.1.3获取数据报内容 2.2.1.4设置数据报内容 2.2.2DatagramSocket类 2.2.2.1构造方法 2.2.2.2常用方法 2.2.3具体代码与解释 3…...

AI+集装箱号码识别技术,主要发展方向和应用潜力

集装箱号码识别技术作为物流数字化的重要工具&#xff0c;其应用前景随着全球供应链的智能化升级和绿色转型需求不断扩大。结合当前技术发展和行业实践&#xff0c;以下是其未来的主要发展方向和应用潜力&#xff1a; 1.物流与港口智能化管理 自动化识别与效率提升&#xff1…...

安装可视化jar包部署平台JarManage

一、下载 下载地址&#xff1a;JarManage 发行版 - Gitee.com &#x1f692; 下载 最新发行版 下载zip的里面linux和windows版本都有 二、运行 上传到服务器&#xff0c;解压进入目录 &#x1f69a; 执行java -jar jarmanage-depoly.jar 命令运行 java -jar jarmanage-dep…...

后端之JPA(EntityGraph+JsonView)

不同表之间的级联操作或者说关联查询是很多业务场景都会用到的。 对于这种需求最朴素的方法自然是手动写关联表&#xff0c;然后对被关联的表也是手动插入数据。但是手写容易最后写成一堆shit代码&#xff0c;而且修改起来也是非常麻烦的。 学会使用现成的工具还是非常有利的…...

Java数据结构第十三期:走进二叉树的奇妙世界(二)

专栏&#xff1a;数据结构(Java版) 个人主页&#xff1a;手握风云 目录 一、二叉树的遍历 1.1. 前序遍历 1.2. 中序遍历 1.3. 后序遍历 1.4. 完整代码 二、二叉树的基本操作 2.1. 获取树中结点个数 2.1. 获取叶子结点个数 2.3. 获取第k层结点的个数 2.4. 获取二叉树的…...

JavaScript系列(86)--现代构建工具详解

JavaScript 现代构建工具详解 &#x1f528; 现代前端开发离不开构建工具&#xff0c;它们帮助我们处理模块打包、代码转换、资源优化等任务。让我们深入了解主流的构建工具及其应用。 构建工具概述 &#x1f31f; &#x1f4a1; 小知识&#xff1a;构建工具主要解决代码转换…...

docker容器网络配置及常用操作

Linux内核实现名称空间的创建 ip netns&#xff08;网络名称空间&#xff09;命令 可以借助ip netns命令来完成对 Network Namespace 的各种操作。ip netns命令来自于iproute安装包&#xff0c;一般系统会默认安装&#xff0c;如果没有的话&#xff0c;请自行安装。 注意&am…...

Docker 性能优化指南

Docker 提供了强大的容器化功能&#xff0c;能够帮助开发者在不同的环境中构建、测试和部署应用。然而&#xff0c;随着容器化应用的不断增长&#xff0c;Docker 容器可能会面临一些性能瓶颈&#xff0c;影响其运行效率、资源占用和扩展能力。为了确保容器在生产环境中的高效运…...

课程1. 深度学习简介

课程1. 深度学习简介 神经网络结构逻辑回归XOR问题&#xff08;异或问题&#xff09; 中间特征的生成全连接神经网络中间网络层的激活函数Sigmoid函数Tanh函数ReLU函数其它激活函数 使用全连接神经网络解决 XOR 问题神经网络用于回归问题训练神经网络 不同类型的神经网络 附加材…...

【cuda学习日记】4.3 结构体数组与数组结构体

4.3 数组结构体&#xff08;AoS&#xff09;和结构体数组&#xff08;SoA&#xff09; AoS方法进行存储 struct innerStruct{float x;float y; };struct innerStruct myAOS[N];SoA方法来存储数据 struct innerArray{float x[N];float y[N]; };struct innerArray moa;如图说明…...

2025最新高维多目标优化:基于城市场景下无人机三维路径规划的导航变量的多目标粒子群优化算法(NMOPSO),MATLAB代码

一、基于导航变量的多目标粒子群优化算法&#xff08;NMOPSO&#xff09;介绍 基于导航变量的多目标粒子群优化算法&#xff08;Navigation variable-based multi-objective particle swarm optimization&#xff0c;NMOPSO&#xff09;是2025年提出的一种用于无人机路径规划的…...

数字IC后端设计实现OCC(On-chip Clock Controller)电路介绍及时钟树综合案例

数字IC后端时钟树综合专题&#xff08;OCC电路案例分享&#xff09; 复杂时钟设计时钟树综合(clock tree synthesis)常见20个典型案例 1、什么是OCC&#xff1f; 片上时钟控制器(On-chip Clock Controllers &#xff0c;OCC)&#xff0c;也称为扫描时钟控制器(Scan Clock Con…...

Linux内核,slub分配流程

我们根据上面的流程图&#xff0c;依次看下slub是如何分配的 首先从kmem_cache_cpu中分配&#xff0c;如果没有则从kmem_cache_cpu的partial链表分配&#xff0c;如果还没有则从kmem_cache_node中分配&#xff0c;如果kmem_cache_node中也没有&#xff0c;则需要向伙伴系统申请…...

本地部署DeepSeek-R1(Ollama+Docker+OpenWebUI知识库)

安装Ollama 打开 Ollama官网 https://ollama.com/下载安装 Ollama服务默认只允许本机访问&#xff0c;修改允许其它主机访问 OLLAMA_HOST0.0.0.0 ollama serve也可以添加系统环境变量 都知道模型体积很大&#xff0c;顺便也通过环境变量修改模型存放位置&#xff0c;我这…...

Java 实现快速排序算法:一条快速通道,分而治之

大家好&#xff0c;今天我们来聊聊快速排序&#xff08;QuickSort&#xff09;算法&#xff0c;这个经典的排序算法被广泛应用于各种需要高效排序的场景。作为一种分治法&#xff08;Divide and Conquer&#xff09;算法&#xff0c;快速排序的效率在平均情况下非常高&#xff…...

低成本GPU部署方案:Ostrakon-VL扫描终端显存优化与Smart Resizing详解

低成本GPU部署方案&#xff1a;Ostrakon-VL扫描终端显存优化与Smart Resizing详解 1. 项目背景与核心价值 在零售与餐饮行业数字化转型浪潮中&#xff0c;视觉识别技术正发挥着越来越重要的作用。然而传统解决方案往往面临两大痛点&#xff1a;一是工业级UI设计过于沉闷&…...

智能编码平台上线72小时后崩溃?揭秘代码生成器与APM系统割裂导致的5大可观测性断层

第一章&#xff1a;智能编码平台上线72小时后崩溃&#xff1f;揭秘代码生成器与APM系统割裂导致的5大可观测性断层 2026奇点智能技术大会(https://ml-summit.org) 当AI生成的Go服务在Kubernetes集群中每秒创建37个goroutine却未触发任何APM告警时&#xff0c;崩溃已成定局。根…...

[RV1109/RV1126实战]-RGA与DRM协同优化:从零构建图像Resize加速引擎

1. 为什么需要RGA与DRM协同优化图像Resize&#xff1f; 在嵌入式视觉开发中&#xff0c;图像缩放&#xff08;Resize&#xff09;是最基础也是最耗时的操作之一。我在RV1126平台上实测发现&#xff0c;用OpenCV的resize函数处理一张640x480的RGB图像需要22ms&#xff0c;而同样…...

SITS2026案例深度拆解:为什么同一Prompt在Kubernetes集群A生成合规代码,在集群B触发安全熔断?(附YAML级差异比对表)

第一章&#xff1a;SITS2026案例&#xff1a;AI云原生代码生成 2026奇点智能技术大会(https://ml-summit.org) SITS2026&#xff08;Smart Intelligent Transformation Suite 2026&#xff09;是面向金融核心系统的云原生AI工程实践平台&#xff0c;其核心能力之一是基于多模…...

抖音视频下载终极指南:douyin-downloader完整使用教程

抖音视频下载终极指南&#xff1a;douyin-downloader完整使用教程 【免费下载链接】douyin-downloader A practical Douyin downloader for both single-item and profile batch downloads, with progress display, retries, SQLite deduplication, and browser fallback suppo…...

别光看菜单了!HFSS 2023 R2工作界面保姆级拆解:从建模到仿真的高效操作流

HFSS 2023 R2界面深度优化指南&#xff1a;从功能认知到效率革命 第一次打开HFSS 2023 R2时&#xff0c;那个充满各种窗口和工具栏的界面可能会让你感到些许压迫感。但别担心&#xff0c;这就像飞行员第一次坐进战斗机驾驶舱——看似复杂的仪表盘背后&#xff0c;其实隐藏着精…...

Afilmory多存储适配器架构:支持S3、GitHub、Eagle等8种存储源

Afilmory多存储适配器架构&#xff1a;支持S3、GitHub、Eagle等8种存储源 【免费下载链接】afilmory Modern photo gallery for photographers, with S3/GitHub sync, EXIF details, maps, and a WebGL viewer. 项目地址: https://gitcode.com/gh_mirrors/iris71/afilmory …...

Unity UGUI Dropdown向上展开?一个Pivot和Anchor的调整就搞定(附完整C#代码)

Unity UGUI Dropdown向上展开的终极解决方案&#xff1a;Pivot与Anchor深度解析 在Unity的UI开发中&#xff0c;Dropdown组件是构建交互式菜单的常用工具。但当你需要在屏幕底部放置一个下拉菜单时&#xff0c;可能会遇到一个令人头疼的问题——默认向下展开的Dropdown列表会被…...

基于AXI总线的Cortex-M3软核SoC设计与外设集成

1. Cortex-M3软核与AXI总线基础解析 第一次接触Cortex-M3软核是在三年前的一个物联网安全项目&#xff0c;当时需要在FPGA上实现一个轻量级加密处理器。和大多数嵌入式开发者一样&#xff0c;我之前主要使用现成的STM32系列芯片&#xff0c;直到真正动手在Vivado里搭建M3软核&a…...

告别卡顿!Jetson Nano上优化VNC远程桌面的完整配置指南(基于Ubuntu 18.04)

Jetson Nano远程桌面性能优化实战&#xff1a;从卡顿到流畅的终极指南 在嵌入式开发领域&#xff0c;Jetson Nano凭借其强大的AI计算能力和紧凑的尺寸&#xff0c;成为众多开发者的首选平台。然而&#xff0c;当需要通过VNC远程操作图形界面时&#xff0c;许多用户都会遇到令人…...