news 2026/2/17 2:14:26

排序算法:冒泡排序

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
排序算法:冒泡排序

冒泡排序(Bubble Sort)详解

冒泡排序是一种基础的交换排序算法,核心思想是:重复遍历待排序数组,每次比较相邻的两个元素,若顺序错误则交换它们,直到没有元素需要交换为止。

资料:https://pan.quark.cn/s/43d906ddfa1bhttps://pan.quark.cn/s/90ad8fba8347https://pan.quark.cn/s/d9d72152d3cf

核心特点
  • 稳定性:稳定(相等元素的相对位置不变)
  • 时间复杂度
    • 最好情况(已排序):O(n)(需优化标志位)
    • 最坏情况(逆序):O(n²)
    • 平均情况:O(n²)
  • 空间复杂度:O(1)(原地排序)
  • 适用场景:小规模数据、对稳定性有要求的简单场景

算法原理

  1. 从数组第一个元素开始,依次比较相邻的两个元素(如arr[i]arr[i+1]);
  2. arr[i] > arr[i+1](升序),则交换两者位置;
  3. 一轮遍历结束后,最大的元素会“冒泡”到数组末尾
  4. 重复上述过程,每轮遍历的终点向前收缩一位(已排序的末尾元素无需再比较);
  5. 若某一轮遍历中没有发生任何交换,说明数组已完全有序,可提前终止(优化)。

代码实现(Python)

defbubble_sort(arr):# 复制数组避免修改原数据arr_copy=arr.copy()n=len(arr_copy)# 外层循环:控制遍历轮数(最多n-1轮)foriinrange(n-1):# 标志位:标记本轮是否发生交换(优化)swapped=False# 内层循环:每轮比较到未排序的最后一位(n-1-i)forjinrange(n-1-i):# 升序:前一个元素大于后一个则交换ifarr_copy[j]>arr_copy[j+1]:arr_copy[j],arr_copy[j+1]=arr_copy[j+1],arr_copy[j]swapped=True# 若本轮无交换,说明数组已有序,提前退出ifnotswapped:breakreturnarr_copy# 测试示例if__name__=="__main__":# 无序数组unsorted_arr=[64,34,25,12,22,11,90]sorted_arr=bubble_sort(unsorted_arr)print("原始数组:",unsorted_arr)print("排序后数组:",sorted_arr)# 输出:[11, 12, 22, 25, 34, 64, 90]# 已排序数组(验证优化)sorted_test=[1,2,3,4,5]print(bubble_sort(sorted_test))# 仅1轮遍历即退出

代码实现(Java)

publicclassBubbleSort{publicstaticint[]bubbleSort(int[]arr){// 复制数组避免修改原数据int[]arrCopy=Arrays.copyOf(arr,arr.length);intn=arrCopy.length;for(inti=0;i<n-1;i++){booleanswapped=false;// 交换标志位// 内层循环:每轮减少i次比较(末尾i个已排序)for(intj=0;j<n-1-i;j++){if(arrCopy[j]>arrCopy[j+1]){// 交换元素inttemp=arrCopy[j];arrCopy[j]=arrCopy[j+1];arrCopy[j+1]=temp;swapped=true;}}// 无交换则提前终止if(!swapped){break;}}returnarrCopy;}publicstaticvoidmain(String[]args){int[]unsortedArr={64,34,25,12,22,11,90};int[]sortedArr=bubbleSort(unsortedArr);System.out.print("原始数组:");for(intnum:unsortedArr)System.out.print(num+" ");System.out.print("\n排序后数组:");for(intnum:sortedArr)System.out.print(num+" ");}}

关键优化点

  1. 提前终止:通过swapped标志位,若某轮无交换则直接退出,避免无效遍历;
  2. 收缩遍历范围:每轮遍历的终点为n-1-i,因为后i个元素已排序完成;
  3. 双向冒泡(鸡尾酒排序):针对“部分有序”的数组(如[1,3,2,4,5]),可从左到右、再从右到左交替遍历,减少遍历次数。

适用场景

  • 数据量小(n < 1000),对性能要求不高;
  • 需保证排序稳定性;
  • 教学场景(易理解、易实现)。

不适用场景:大数据量(如n > 10000),此时应选择快速排序、归并排序等O(n log n)的算法。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/2/12 16:52:41

Samba as Wins Server

自己做的小小實驗 希望能跨網段透過netbios存取同一工作群組下的電腦 Q1 : 同一工作群組在網路芳鄰重新整理會直接出現 還是要連線後才會出現? 用Samba 當作wins server Alpine Linux 安裝samba apk add samba編輯 /etc/samba/smb.conf vi /etc/samba/smb.conf將 wins supp…

作者头像 李华
网站建设 2026/2/14 5:35:49

电子会计档案管理系统:档案宝如何发挥会计档案的价值?

一、引言&#xff1a;电子会计档案时代&#xff0c;档案宝的价值定位在数字化转型浪潮下&#xff0c;会计档案已从传统纸质存储的 “历史凭证”&#xff0c;转变为企业决策的 “数据资产”。电子会计档案管理系统 “档案宝”&#xff0c;打破了传统档案管理的时空限制与效率瓶颈…

作者头像 李华
网站建设 2026/2/12 16:52:35

计算广告:智能时代的营销科学与实践(二十一)

目录 11.2 担保式投送系统 11.2.1 流量预测 11.2.2 频次控制 11.3 在线分配 11.3.1 在线分配问题 11.3.2 在线分配问题举例 11.3.3 极限性能研究 11.3.4 实用优化算法 总结 11.2 担保式投送系统 担保式投送&#xff08;Guaranteed Delivery&#xff0c; GD&#xff09…

作者头像 李华
网站建设 2026/2/12 16:52:32

计算广告:智能时代的营销科学与实践(二十三)

目录 第13章 竞价广告核心技术 13.1 竞价广告计价算法 1. 从密封竞价到广义第二价格&#xff1a;市场的进化 2. VCG拍卖&#xff1a;理论上的完美与现实的差距 3. 计价算法的工程实现与考量 4. 计价的演进&#xff1a;从CPC到oCPX 13.2 搜索广告系统 13.2.1 查询扩展 1…

作者头像 李华
网站建设 2026/2/15 11:49:45

【完整源码+数据集+部署教程】食品物品检测系统源码分享[一条龙教学YOLOV8标注好的数据集一键训练_70+全套改进创新点发刊_Web前端展示]

一、背景意义 随着全球经济的快速发展和生活水平的不断提高&#xff0c;食品消费市场日益繁荣&#xff0c;食品安全问题也随之凸显。食品物品的检测与识别不仅是保障消费者权益的重要环节&#xff0c;也是提升食品产业链效率的关键因素。传统的食品检测方法多依赖人工检查&…

作者头像 李华
网站建设 2026/2/15 22:36:45

Java小白求职互联网大厂:面试官的技术挑战与业务思考

文章简述 在这篇文章中&#xff0c;我们将模拟一个互联网大厂Java小白求职者的面试场景。面试官通过一系列技术问题&#xff0c;考察求职者的Java核心技术、微服务架构、缓存技术、日志处理等能力&#xff0c;并引导其思考实际业务场景中的应用。本文将详细解析每个问题的答案&…

作者头像 李华