python 实现冒泡排序的思路和代码

当需求提到需要从小到大的排序时,我们很自然的就会想起最基础的“冒泡排序”

冒泡排序的原理就不再多说了,网上有一大堆,以下是python实现冒泡排序的代码。

对于冒泡排序算法,如果有n个数,一共需要进行n-1趟的两两操作,而在n-1趟中的第i趟也需要进行两两对比,无论是从大到小还是从小到大,需要比较n-1-i个数

1. 循环体的思路如下:

最外层的循环次数为n-1

内层的比较次数应该是n-1-i  (每进行第n次比较,就有n个数已经冒泡被确定了下来,剩下的比较数为n-i-1)

内层的代码比较简单,即两个数的比较交换,我们引入一个中间变量作为转接桥梁即可。

 

2.具体循环的实现

由于python中的for...in循环通常是迭代器的作用

那么如何实现次数?

python中的for无法Java中的for(i=0;i<n;i++)这种书写形式,我们需要借助range()函数来实现次数的确定:

如升序的写法如下:

def sort_ascneding(L):
    n = len(L)
    for i in range(0,n):
        for j in range (0,n-i):
            if L[j] > L[j+1]:
                t = L[j]
                L[j] = L[j+1]
                L[j+1] = t
    return L

3.冒泡排序的缺点

虽然好理解,但是太耗时间了

对于较少的数据运用冒泡排序没问题,但当数据量为海量时,电脑性能不好会直接卡死。

比如,你可以在IDE中跑一下如下代码,电脑肯定会死机,别问我是怎么知道的。

def sort_ascneding(L):
    n = len(L)
    for i in range(0,n):
        for j in range (0,n-i):
            if L[j] > L[j+1]:
                t = L[j]
                L[j] = L[j+1]
                L[j+1] = t
    return L
print (sort_ascneding(list(range(99,100000))+list(range(11,100000))))

 

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值