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(numbers) - 1):
    index = i
    for j in range(i+1,len(numbers)):
        if numbers[j] < numbers[index]:
            numbers[j], numbers[index] = numbers[index], numbers[j]
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表示排序规则





猜你喜欢

转载自blog.csdn.net/pzl_pzl/article/details/80981856