排序算法python版(1)-冒泡排序算法

  • 冒泡排序思路:
    列表每两个相邻的元素,如果前一个比后一个大,则将这两个数交换
    经过第一趟排序最大的数交换到了最后一个
    经过第二趟排序第二大的数交换到的倒数第二个

    经过n-1趟排序后,整个列表元素即完成了排序
    整个过程看上去好像是大的数逐渐向后移动,整个效果看上去就像冒泡一样,因此叫做冒泡法

  • 冒泡算法动态图:
    在这里插入图片描述

  • 冒泡排序算法的时间复杂度为O(n2

代码如下:

def bubble_sort(datas):
    for i in range(len(datas)-1):
        for j in range(len(datas)-i-1):
            if datas[j]>datas[j+1]:
                datas[j],datas[j+1]=datas[j+1],datas[j]
        print(f"第 {i+1} 轮排序结果:",datas)
    return datas

if __name__=="__main__":
    datas=[10,9,8,7,6,5,4,3,2,1,0]
    datas=bubble_sort(datas)

执行结果如下:

1 轮排序结果: [9, 8, 7, 6, 5, 4, 3, 2, 1, 0, 10]2 轮排序结果: [8, 7, 6, 5, 4, 3, 2, 1, 0, 9, 10]3 轮排序结果: [7, 6, 5, 4, 3, 2, 1, 0, 8, 9, 10]4 轮排序结果: [6, 5, 4, 3, 2, 1, 0, 7, 8, 9, 10]5 轮排序结果: [5, 4, 3, 2, 1, 0, 6, 7, 8, 9, 10]6 轮排序结果: [4, 3, 2, 1, 0, 5, 6, 7, 8, 9, 10]7 轮排序结果: [3, 2, 1, 0, 4, 5, 6, 7, 8, 9, 10]8 轮排序结果: [2, 1, 0, 3, 4, 5, 6, 7, 8, 9, 10]9 轮排序结果: [1, 0, 2, 3, 4, 5, 6, 7, 8, 9, 10]10 轮排序结果: [0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10]
  • 上述实例展示最坏的情况下,下面测试一下最好情况下:
def bubble_sort(datas):
    for i in range(len(datas)-1):
        for j in range(len(datas)-i-1):
            if datas[j]>datas[j+1]:
                datas[j],datas[j+1]=datas[j+1],datas[j]
        print(f"第 {i+1} 轮排序结果:",datas)
    return datas

if __name__=="__main__":
    datas=[0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10]
    datas=bubble_sort(datas)

执行结果如下:发现最好的情况下,这里仍然进行了10轮循环

1 轮排序结果: [0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10]2 轮排序结果: [0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10]3 轮排序结果: [0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10]4 轮排序结果: [0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10]5 轮排序结果: [0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10]6 轮排序结果: [0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10]7 轮排序结果: [0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10]8 轮排序结果: [0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10]9 轮排序结果: [0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10]10 轮排序结果: [0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10]
  • 下面对上述冒泡法做一点优化,即当检测到已经排序之后,停止继续比较
def bubble_sort(datas):
    for i in range(len(datas)-1):
        has_exchange=False
        for j in range(len(datas)-i-1):
            if datas[j]>datas[j+1]:
                has_exchange=True
                datas[j],datas[j+1]=datas[j+1],datas[j]
        print(f"第 {i+1} 轮排序结果:",datas)
        if not has_exchange:
            break
    return datas

if __name__=="__main__":
    datas=[0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10]
    datas=bubble_sort(datas)

执行结果如下:此时已经做到了在最好的情况下,只需要比较一轮,即比较一轮发现已经排好序了,就停吃继续比较了

1 轮排序结果: [0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10]
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

redrose2100

您的鼓励是我最大的创作动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值