python-基本算法(冒泡)
冒泡排序算法的运作如下:
- 比较相邻的元素。如果第一个比第二个大,就交换他们两个。
- 对每一对相邻元素作同样的工作,从开始第一对到结尾的最后一对。在这一点,最后的元素应该会是最大的数。
- 针对所有的元素重复以上的步骤,除了最后一个。
- 持续每次对越来越少的元素重复上面的步骤,直到没有任何一对数字需要比较。
一句话概括:相邻元素比较,大的放在后面
冒泡排序原理: 每一趟只能将一个数归位, 如果有n个数进行排序,只需将n-1个数归位,
也就是说要进行n-1趟操作(已经归位的数不用再比较,因为已经是最大)。
# coding:utf-8
nums = [12, 99, 18, 76, 2]
count = len(nums)
for i in range(0, count-1): # 这个循环负责设置冒泡排序进行的次数
for j in range(0, count-i-1):
if nums[j] > nums[j+1]:
nums[j], nums[j+1] = nums[j+1], nums[j] # 交换
print(nums)
运行结果:
[12, 18, 76, 2, 99] #第一轮,把最大的数(99)放到最后一位
[12, 18, 2, 76, 99] #第二轮,把第二大的数(76)放到倒数第二位
[12, 2, 18, 76, 99] #第三轮,把第三大的数(18)放到倒数第三位
[2, 12, 18, 76, 99] #第四轮,把第四大的数(12)放到倒数第四位
优化:如果在循环的时候,有一次没有进行交换,就表示数列中的数据已经是有序的
时间复杂度:最好情况是0(n),只遍历一次,一般情况和最坏情况都是O(n^2)
def bubble_sort(lst):
for i in range(len(lst)-1): # 这是需要循环遍历多少次
change = False # 做一个标志变量
for j in range(len(lst)-1-i): # 每次数组中的无序区
if lst[j] >lst[j+1]:
lst[j],lst[j+1] = lst[j+1],lst[j]
change = True # 每次遍历,如果进来排序的话,就会改变change的值
if not change: # 如果change没有改变,那就表示当前的序列是有序的,直接跳出循环即可
return
lst = [11, 22, 4, 13, 55,9]
bubble_sort(lst)
print(lst)
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· AI与.NET技术实操系列:基于图像分类模型对图像进行分类
· go语言实现终端里的倒计时
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 分享一个免费、快速、无限量使用的满血 DeepSeek R1 模型,支持深度思考和联网搜索!
· 25岁的心里话
· 基于 Docker 搭建 FRP 内网穿透开源项目(很简单哒)
· ollama系列01:轻松3步本地部署deepseek,普通电脑可用
· 按钮权限的设计及实现