栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > Python

python实现冒泡排序算法

Python 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

python实现冒泡排序算法

冒泡排序是指对于一串无序列表,比如list = [6, 5, 4, 3, 2, 9.5,1],两两比较并将大的数字往列表右边放置,最终生成结果从小到大的排序列表[1, 2, 3, 4, 5, 6, 9.5]
完整代码如下:

def bubble_sort(list):
    index = len(list) - 1  # 获取最大未排序索引
    flag = False
    while flag == False: #  not sorted
        flag = True
        for i in range(index):
            if list[i] > list[i+1]:
                flag = False
                list[i],list[i + 1] = list[i + 1],list[i]  # 两列数据互换
        index = index - 1
list = [6, 5, 4, 3, 2, 9.5,1]
bubble_sort(list)
print(list)

具体思路分析

  1. 获取最大未排序索引,初始状态下也就是列表长度减一,因为列表第一个数字的索引为0,即index = len(list) - 1
  2. 设定初始状态下flag = False,通过flag值判定此列表是否已经完成排序,False表示未排序,True表示已完成排序
  3. 当未排序时,则会进入父循环
    while flag == False: #  not sorted
        flag = True

并且进入父循环时,将排序标志记为已完成
4. 之后就是按部就班的比较相邻两个数字的大小

        for i in range(index):
            if list[i] > list[i+1]:
                flag = False
                list[i],list[i + 1] = list[i + 1],list[i]  # 两列数据互换
        index = index - 1
转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/689264.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号