python中的三大排序 pk list自带排序

1:冒泡排序算法的原理如下:
  1. 比较相邻的元素。如果第一个比第二个大,就交换他们两个。
  2. 对每一对相邻元素做同样的工作,从开始第一对到结尾的最后一对。在这一点,最后的元素应该会是最大的数。
  3. 针对所有的元素重复以上的步骤,除了最后一个。
  4. 持续每次对越来越少的元素重复上面的步骤,直到没有任何一对数字需要比较。

# 冒泡 排序
time1 = time.clock()
numbers = [34, 26, 77, 100, 1, 20, -66, 666]
#从小到大排序
for i in range(len(numbers) - 1):
    for j in range(len(numbers) - 1 - i):
        if numbers[j] > numbers[j + 1]:
            numbers[j], numbers[j + 1] = numbers[j + 1], numbers[j]
print(numbers,time.clock()-time1)
执行结果:[-66, 1, 20, 26, 34, 77, 100, 666] 2.586442606838554e-05
2:选择排序也是一种简单直观的排序算法。它的工作原理很容易理解:
初始时在序列中找到最小(大)元素,放到序列的起始位置作为已排序序列;
然后,再从剩余未排序元素中继续寻找最小(大)元素,放到已排序序列的末尾。
以此类推,直到所有元素均排序完毕。
for i in range(len(A)): 
      
   
    min_idx = i 
    for j in range(i+1, len(A)): 
        if A[min_idx] > A[j]: 
            min_idx = j 
                
    A[i], A[min_idx] = A[min_idx], A[i] 
print(numbers,time.clock()-time1)

执行结果:[-66, 1, 20, 26, 34, 77, 100, 666] 2.2990600949676037e-05

 3:直接插入排序基本思想是每一步将一个待排序的记录,插入到前面已经排好序的有序序列中去,直到插完所有元素为止。

for i in range(1, len(numbers)):
    j = i - 1
    if numbers[i] < numbers[j]:
        temp = numbers[i]
        numbers[i] = numbers[j]
        j = j - 1
        while j >= 0 and temp < numbers[j]:
            numbers[j + 1] = numbers[j]
            j = j - 1
        numbers[j + 1] = temp
print(numbers, time.clock() - time1)
执行结果:[-66, 1, 20, 26, 34, 77, 100, 666] 1.68324042667271e-05
4 list排序 sort方法

 
time1 = time.clock()
numbers = [34, 26, 77, 100, 1, 20, -66, 666]
numbers.sort()
print(numbers,time.clock()-time1)
执行结果:[-66, 1, 20, 26, 34, 77, 100, 666] 3.2843715642394342e-06
速度比上面都快,reverse表示排序规则

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值