排序-冒泡算法分析和python代码实现

原理描述:

1、列表中,每次对比两个相邻的元素,如果前面的比后面的大,则交换->将最大数不停往队列后面走
2、每查询一趟,则有序区间增加一个数字(队列尾部),无序区间减少一个数字

代码实现:

def bubble_sort(li):
    for i in range(len(li) - 1):
        exchange = False
        for j in range(len(li) - 1 - i):
            if li[j] > li[j + 1]:
                li[j + 1], li[j] = li[j], li[j + 1]
                exchange = True
        print("第%d趟之后:%s" % (i + 1, li))
        if not exchange:  # 如果一趟遍历完成,无序区里面任意2个位置都没有交换,则说明无序区也是有序的,则可以退出排序
            print("当前i的位置%d,当li[i]=%d队列已经有序,停止排序" % (i, li[i]))
            return


li = list(range(100))
import random
random.shuffle(li)
# li = [1, 2, 3, 4, 5, 6, 7, 8]

bubble_sort(li)
print("after sort:", li)

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值