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

排序算法:冒泡排序

冒泡排序(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)的算法。

http://www.cnnetsun.cn/news/138397.html

相关文章:

  • 2025年战略咨询在行业标准演进中的推动力
  • 【电商API接口】电商平台价格监控行业全景:数据驱动的定价革命
  • java计算机毕业设计蔬菜配送系统 生鲜直配平台的设计与实现 社区蔬菜一站式采购与配送管理系统
  • dubbo源码之一次RPC请求的生死之旅(基于Dubbo 2.7.8)
  • 基于SpringBoot+Vue的web城乡居民基本医疗信息管理系统管理系统设计与实现【Java+MySQL+MyBatis完整源码】
  • 【完整源码+数据集+部署教程】手势与标志识别检测系统源码[一条龙教学YOLOV8标注好的数据集一键训练_70+全套改进创新点发刊_Web前端展示]
  • 03.统计学机器学习
  • [Poi2011]Lightning Conductor题解
  • 一文读懂大模型:收藏级教程,助你从入门到精通
  • Nginx云计算大数据——安装AND版本升级(普通升级+平滑升级+失败回滚)
  • GPT-5.2 实测数据流出:逻辑推理性能翻倍,大模型“幻觉”真的被终结了吗?
  • SQL SERVER——通过计划任务方式每月对配置数据、审计数据等进行备份
  • 前端——跨平台桌面应用开发实践
  • OpenAI 的反击!GPT-5.2 强行拉开代差,Gemini 3 和 Claude 4 还有机会吗?
  • 零售打工人加薪难?靠这张证,我在激烈竞争里站稳了脚跟
  • 基于springboot的多媒体素材库的开发与应用毕业论文+PPT(附源代码+演示视频)
  • 从离线语音到多模态智能体四博智联 AI 硬件整体解决方案全景解析
  • 我发现跨医院联合训练让诊断准确率飙升后来才知道是横向联邦学习在数据孤岛中的绝招
  • 性能压测工具:wrk
  • 论文引用标注工具排名2025:6大平台+自动规范推荐
  • Kotaemon AWS EC2部署实例:国际业务首选
  • 实在没货,简历(软件测试)咋写?
  • 网约车服务端线上流量巡检与测试验收技术
  • 公考日记7
  • 火电一次调频、自抗扰调频及群智能算法智能调频在MATLAB/Simulink中的应用
  • 科研实验室温湿度监控新范式:以太网 POE 技术全场景解决方案
  • RV1126 NO.57:ROCKX+RV1126人脸识别推流项目之读取人脸图片并把特征值保存到sqlite3数据库
  • 探索SAR ADC:45nm工艺下的高速高精度设计
  • 【小增长技术团队东哥分享】Electron vs Electron-Vite vs Electron-Egg:桌面端开发到底该选谁?
  • 测试价值的量化评估:从成本中心到价值证明的路径探索