冒泡排序
本文为作者原创,转载请注明出处:https://www.cnblogs.com/zzsy/p/12684828.html
冒泡排序
- 通过对列表中的元素进行两两比较,数值大的交换位置,知道最后一个,依次比较,得出有序序列。
def pao(alist):
x = 1
while x<=len(alist):
for i in range(len(alist)-x): #当每次比较出来最大值会在最后,所以当第二次循环比较的时候,最后一次不需要循环比较,依次减去得出最大值的次数。
if alist[i] > alist[i+1]:
alist[i],alist[i+1] = alist[i+1],alist[i]
x = x+1
return alist
冒泡思路
#1.将乱序序列中的最大值找出,逐一移动到序列最后的位置
alist = [3,8,5,7,6]
def sort(alist):
#找最大值的方式是通过对列表中的元素进行两两比较,值大的元素逐步向后移动
#序列中有n个元素,两两比较的话,需要比较n-1次
for i in range(len(alist)-1): #循环n-1次,控制两两比较的次数
if alist[i] > alist[i+1]:#如果前面的元素大于后面的元素,交换两个元素的位置
alist[i],alist[i+1] = alist[i+1],alist[i]
else:#如果后面的元素大于前面的元素,则不作任何操作
pass
return alist
print(sort(alist))
[3, 5, 7, 6, 8]
- 发现上述代码已经可以将序列中的最大值放置到合适的位置,然后我们就可以将上述操作继续作用到n-1个元素对应的新序列,则就可以将n-1个元素对应的最大值放置到了n-1个元素的最后位置。
- 结论:发现如果将上述的操作逐步的作用n-1次就可以将整个序列变成有序的。
#2.将步骤一的操作继续作用n-1次
alist = [3,8,5,7,6]
def sort(alist):
for j in range(len(alist)-1):#外层循环次数递增,内层循环次数递减
for i in range(len(alist)-1-j): #循环n-1次,控制两两比较的次数
if alist[i] > alist[i+1]:#如果前面的元素大于后面的元素,交换两个元素的位置
alist[i],alist[i+1] = alist[i+1],alist[i]
else:#如果后面的元素大于前面的元素,则不作任何操作
pass
return alist
print(sort(alist))
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】凌霞软件回馈社区,博客园 & 1Panel & Halo 联合会员上线
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· .NET 9 new features-C#13新的锁类型和语义
· Linux系统下SQL Server数据库镜像配置全流程详解
· 现代计算机视觉入门之:什么是视频
· 你所不知道的 C/C++ 宏知识
· 聊一聊 操作系统蓝屏 c0000102 的故障分析
· 不到万不得已,千万不要去外包
· C# WebAPI 插件热插拔(持续更新中)
· .NET 9 new features-C#13新的锁类型和语义
· 会议真的有必要吗?我们产品开发9年了,但从来没开过会
· 《SpringBoot》EasyExcel实现百万数据的导入导出