当前位置:   article > 正文

【数据结构】手写快速排序

【数据结构】手写快速排序

一、理念

什么是快速排序

首先确立pivot,比如下图位于末尾

然后i遍历3到6

在3的时候,j指向i前面一位

如果3<=5(pivot),那么j++,同时将i与j指向的交换,第一次交换是原地不动

一直到遇见9,此时j不动,然后i指向2,j++,j指向9,此时2与9交换,也就是将小的与大的交换。快速排序所要达到的目的是,每轮大循环,确定pivot的位置,以及保证pivot左边都是小于等于他,右边都是大于他

可以看到这里i走到了头,出了循环,此时将pivot与j+1指向的交换,确定了pivot的位置

然后5的左右两边分别再次进行快排

二、手写代码

  1. import random
  2. '''1 首先start不能小于last,退出边界
  3. 2 选择pivot放在last位置上
  4. 3 遍历start到last-1位置上的数a
  5. 如果a<=pivot,则与j指向的值原地交换
  6. 如果a>pivot,则j不变,等到下次a>pivot,则a与这个j指向的大值交换
  7. 4 循环结束,j+1指向的与pivot交换,将pivot放在合适的位置上,
  8. 左边都是小于等于的,右边都是大于他的
  9. 5 继续执行快排,分别执行j左边和右边部分 '''
  10. def quick_sort(nums, start, last):
  11. if start >= last:
  12. return
  13. first = start
  14. '''# 1 pivot随机选择
  15. pivot_index = random.randint(start, last)
  16. nums[pivot_index], nums[last] = nums[last], nums[pivot_index]
  17. pivot = nums[last]
  18. # 2 选第一个
  19. nums[first], nums[last] = nums[last], nums[first]
  20. pivot = nums[first]'''
  21. #3 选最后一个
  22. pivot = nums[last]
  23. j = start - 1
  24. for i in range(start, last):
  25. if nums[i] <= pivot:
  26. j += 1
  27. nums[j], nums[i] = nums[i], nums[j]
  28. nums[j + 1], nums[last] = nums[last], nums[j + 1]
  29. print(nums)
  30. print('j:', j, 'pivot:', pivot)
  31. quick_sort(nums, first, j)
  32. quick_sort(nums, j + 2, last)
  33. if __name__ == '__main__':
  34. nums = arr = [3, 1, 4, 1, 5, 9, 2, 6, 5, 3, 5]
  35. quick_sort(nums, 0, len(nums) - 1)
  36. print("Sorted array is:", nums)

三、时间复杂度 

O(NlogN)

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/神奇cpp/article/detail/852714
推荐阅读
相关标签
  

闽ICP备14008679号