[关闭]
@bergus 2015-12-04T15:13:16.000000Z 字数 1632 阅读 2911

python快速排序

python 算法 快速排序


快速排序采用的思想是分治思想。
快速排序是找出一个元素(理论上可以随便找一个)作为基准(pivot),然后对数组进行分区操作,使基准左边元素的值都不大于基准值,基准右边的元素值 都不小于基准值,如此作为基准的元素调整到排序后的正确位置。递归快速排序,将其他n-1个元素也调整到排序后的正确位置。最后每个元素都是在排序后的正 确位置,排序完成。所以快速排序算法的核心算法是分区操作,即如何调整基准的位置以及调整返回基准的最终位置以便分治递归。

  1. def quickSort(L, low, high):
  2. i = low
  3. j = high
  4. if i >= j:
  5. return L
  6. key = L[low]
  7. while i < j:
  8. while i < j and L[j] >= key:
  9. j = j - 1
  10. L[i] = L[j]
  11. while i < j and L[i] <= key:
  12. i = i + 1
  13. L[j] = L[i]
  14. L[i] = key
  15. quickSort(L, low, i - 1)
  16. quickSort(L, j + 1, high)
  17. return L
  18. L = [1, 2, 5, 1, 3, 6, 2, 8, 11, 33, 22]
  19. print quickSort(L, 0, len(L) - 1)
  20. --------------------
  21. #下面的算法多做了一步交换大小,所以没有上面的算法好
  22. def sub_sort(array,low,high):
  23. key = array[low]
  24. while low < high:
  25. while low < high and array[high] >= key:
  26. high -= 1
  27. while low < high and array[high] < key:
  28. array[low] = array[high]
  29. low += 1
  30. array[high] = array[low]
  31. array[low] = key
  32. return low
  33. def quick_sort(array,low,high):
  34. if low < high:
  35. key_index = sub_sort(array,low,high)
  36. quick_sort(array,low,key_index)
  37. quick_sort(array,key_index+1,high)
  38. ---------------------
  39. import sys
  40. def partion(array, p, r):
  41. x = array[r]
  42. i = p - 1
  43. for j in range(p, r):
  44. if (array[j] < x):
  45. i+=1
  46. array[j], array[i] = array[i], array[j]
  47. i+=1
  48. array[i], array[r] = array[r], array[i]
  49. return i
  50. def quick_sort(array, p, r):
  51. if p < r:
  52. q = partion(array, p, r)
  53. quick_sort(array, p, q - 1)
  54. quick_sort(array, q + 1, r)
  55. ---------------
  56. #下面的算法只用了一行代码就搞定了,真是极客
  57. def quick_sort(ls):
  58. return [] if ls == [] else quick_sort([y for y in ls[1:] if y < ls[0]]) + [ls[0]] + quick_sort([y for y in ls[1:] if y >= ls[0]])

分析
快速排序的时间主要耗费在划分操作上,对长度为k的区间进行划分,共需k-1次关键字的比较。
最坏情况是每次划分选取的基准都是当前无序区中关键字最小(或最大)的记录,划分的结果是基准左边的子区间为空(或右边的子区间为空),而划分所得的另一个非空的子区间中记录数目,仅仅比划分前的无序区中记录个数减少一个。时间复杂度为O(n*n)
在最好情况下,每次划分所取的基准都是当前无序区的"中值"记录,划分的结果是基准的左、右两个无序子区间的长度大致相等。总的关键字比较次数:O(nlgn)
尽管快速排序的最坏时间为O(n2),但就平均性能而言,它是基于关键字比较的内部排序算法中速度最快者,快速排序亦因此而得名。它的平均时间复杂度为O(nlgn)。

添加新批注
在作者公开此批注前,只有你和作者可见。
回复批注