首页 > 编程语言 >python算法:详细图解: 排序:冒泡排序

python算法:详细图解: 排序:冒泡排序

时间:2024-05-16 12:30:44浏览次数:17  
标签:排序 python 交换 冒泡排序 遍历 图解 data 比较

一,什么是冒泡排序?

1,冒泡排序和快速排序都属于交换排序
所谓交换,就是对序列中两个元素根据键值的比较结果来对换这两个记录在序列中的位置
交换排序的特点:将键值较大的元素向序列的尾部移动,键值较小的元素向序列的前部移动

2,冒泡排序:Bubble Sort,是一种最基础的交换排序,
冒泡排序:从序列的一端开始往另一端冒泡,依次比较相邻的两个数的大小,
按需要对数据进行交换,达到最终的排序效果

3,排序过程:以升序排序为例:
设数组长度为n

a, 每轮比较相邻的前后两个数据,如果前面数据大于后面的数据,就将二个数据交换。
b, 每轮都对未排序部分进行遍历,
最大的数据会被交换到未排序部分的最后,
下一轮循环时,对比较的数字范围-1,
不再比较已交换到最后的最大数字

二,示意图:

1,冒泡排序的过程
第一轮遍历前的数据:

比较3和5,无需交换

比较5和9,无需交换

比较9和7,需要交换:

比较9和2,需要交换

比较9和1,需要交换

第二轮遍历后的结果:(注意此轮不再比较最后的9,只比较前5个数字即可)

第三轮遍历后的结果:(注意此轮不再比较最后的7、9,只比较前4个数字即可)

第四轮遍历后的结果:

第五轮遍历后的结果:

最终结果:

2, 总结:
设数据长度为n

a,需要进行多少轮冒泡?
n-1轮,-1是因为剩下最后一个数字之后无需再排序
b,每轮要比较多少个数字?
设当前为第i轮(从0开始),需要比较n-i个数字
c, 每轮要比较多少次?
因为每次比较两个,到最后一个数字时无需再比较,所以需要比较n-i-1次

三,动画演示:

说明:刘宏缔的架构森林—专注it技术的博客,
网址:https://imgtouch.com
本文: https://blog.imgtouch.com/index.php/2024/04/12/python-suan-fa-pai-xu-mao-pao-pai-xu/
代码: https://github.com/liuhongdi/ 或 https://gitee.com/liuhongdi
说明:作者:刘宏缔 邮箱: [email protected]

四,演示代码:

代码:

1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 # data:要排序的数据 def bubble(data):     n = len(data)        # 得到数据长度n     # 排序,对数据遍历n-1轮,因为最后剩下一个元素时,无需再排     for i in range(n - 1):         end = n - i - 1     # 每轮需比较n-i个数据,共需比较n-i-1次         for j in range(0, end):    # 开始比较相邻的两个数据             if (data[j] > data[j + 1]):   # 前一个元素>后一个元素时,交换                 data[j], data[j + 1] = data[j + 1], data[j]         print(f"第{i + 1}轮排序后:", data)     data = [3, 5, 9, 7, 2, 1] print("排序开始前:", data) bubble(data) print("排序完成后:", data)

运行结果:

排序开始前: [3, 5, 9, 7, 2, 1]
第1轮排序后: [3, 5, 7, 2, 1, 9]
第2轮排序后: [3, 5, 2, 1, 7, 9]
第3轮排序后: [3, 2, 1, 5, 7, 9]
第4轮排序后: [2, 1, 3, 5, 7, 9]
第5轮排序后: [1, 2, 3, 5, 7, 9]
排序完成后: [1, 2, 3, 5, 7, 9]

五,总结

冒泡排序:有两个嵌套的循环,用时间较长
平均时间复杂度: O(n²)
最差情形复杂度: O(n²)
空间复杂度: O(1)

标签:排序,python,交换,冒泡排序,遍历,图解,data,比较
From: https://www.cnblogs.com/architectforest/p/18195759

相关文章

  • python算法:阿米巴分裂
    一,阿米巴分裂的题目:阿米巴虫用简单分裂的方式繁殖,它每分裂一次要用3分钟,3分钟后会分裂成为2只。将若干个阿米巴放在一个盛满营养液的容器内,45分钟后容器内充满了阿米巴。已知容器最多能够装220只阿米巴。试问,开始的时候往容器内放了多少个阿米巴?二,解析一:分析:已知45......
  • python算法:打字员问题
    一,题目:现有一堆稿件,甲单独打字完成需要6小时,乙单独打字完成需要10小时,甲工作了若干小时后因家中有事由乙接着干,两人完成稿件一共用了7小时,问甲打字用了几个小时?二,解析:1,为了方便计算,我们假设这堆稿件分成60份,可以得到:甲每小时打10份,乙每小时打6份,设甲用时x,取值范围:[......
  • python算法:篮球联赛
    一,篮球联赛题目某大学举办一次全校学生篮球联赛,全校共n支球队,采用单循环制(每两支队之间比赛一场),一共需要进行多少场比赛?二,解析:思路:我们假设按出场顺序进行比赛只有第一个队时,无法比赛第二个队出场时,与1队比赛一场,可得:f(2)=1第三个队出场时,与1队,2队各比赛一场,可以得到......
  • python3.8下载过程
    python网址:https://www.python.org/ 下载——————————————选downloads下的windows 稍微等待一会后进入此界面 向下滑,找到3.8.0(python版本并不是按顺序排列的) 选择适合自己的版本下载——————其中X86适用于32系统,X86-64适合64的web-based:透过网......
  • python算法:握手问题
    一,题目小明在家中举办派对,请邀请好友来参加,来参加宴会的每两个人之间要握手,而且是仅握手一次,则当人数为n时总共需要握手多少次?二,解析1,思路:我们假设每个人到达后按先后顺序握手:这样从人数最少时开始分析:开始时会场中只有小明,是参会的第一个人,假设第二个人到达时,与小明握......
  • python算法:常胜将军
    一,题目有火柴21根,两人依次取,每次每人只可取走1~4根,不能多取,也不能不取,谁取到最后一根火柴谁输。请编写一个人机对弈程序,要求人先取,计算机后取;计算机为“常胜将军”。二,解析要想让计算机是“常胜将军”,就需要让人取到最后一根火柴。这个怎么实现?就是在倒数第二轮时计算机只剩......
  • python算法:求车速
    一,for循环:1,功能:重复执行同一段代码语法:forindexinrange(n):   #循环体代码index:用来依次接收可迭代对象中的元素的变量名range()函数:负责返回整数序列流程图:2,应用range可以同时指定start和stop,用for遍历并打印1234#指定start和s......
  • python算法:新郎新娘
    一,for循环:1,功能:重复执行同一段代码语法:forindexinrange(n):   #循环体代码index:用来依次接收可迭代对象中的元素的变量名range()函数:负责返回整数序列流程图:2,应用range可以同时指定start和stop,用for遍历并打印1234#指定start和s......
  • python算法:五家共井
    一,for循环:1,功能:重复执行同一段代码语法:forindexinrange(n):   #循环体代码index:用来依次接收可迭代对象中的元素的变量名range()函数:负责返回整数序列流程图:2,应用range可以同时指定start和stop,用for遍历并打印1234#指定start和s......
  • python算法:青蛙跳台阶二
     一,认识递归函数1,什么是递归?递归的工作原理是,如果函数需要处理的问题大小合适,则直接求解并返回结果,否则将问题分解成两个或多个更小的子问题,并对子问题进行相同的处理,直到问题无法分解为止2,什么是递归函数:递归函数(recursivefunction)是指在函数体中可以调用自己的函数3......