快速排序原理及实现
程序员文章站
2022-03-24 13:09:23
...
快速排序的步骤:
- 从数组中选择一个基准数(选择哪一个没有关系,为了方便一般选第一个或者最后一个,也可以随机选择)。
- 把小于基准数的数移动到基准数左边,大于基准数的数移动到基准数右边,和基准值相同的数可以放到任意一边。此时,基准数左边的所有值都小于右边的任意值。
- 对于左右两边的子数组,重复以上操作,直到数组有序。
如果可以开辟新数组保存结果,用python可以很快地写出代码。但如果要求不使用额外数组空间、在原地完成排序,应该怎么办呢?(面试、考试一般都要求这样)对于第二步,历史上曾提出过许多种方法,在现在刷题时不同的人也会使用不同的方法。
下面介绍一个比较常见的交换法,仅仅看很难理解其中的原理,自己画图走一遍将会恍然大悟!
- 选择数组的第一个元素
a[0]
作为pivot,设置两个指针,i
指向最左边的元素a[0]
,j
指向最右边的元素a[n-1]
。 - 比较
a[j]
和pivot
,当a[j] >= pivot
时j
指针向左移动一位,直到a[j] < pivot
。 - 将
a[j]
填到a[i]
中 - 比较
a[i]
和pivot
,当a[i] <= pivot
时left
指针向右移动一位,直到a[i] > pivot
。 - 将
a[i]
填到a[j]
中 - 不断重复2、3、4、5步骤
- 当
i
指针和j
指针重合时,令a[i] = pivot
,此时pivot
的左边所有元素都小于等于pivot
,右边所有元素都大于等于pivot
。 - 对于pivot左边和右边的元素组成的数组,如果长度大于二,则递归进行1到5步。
代码:
def quickSort(nums: list) -> list:
def sortArray(nums: list, left: int, right: int) -> list:
i, j = left, right
if i < j:
piviot = nums[i]
while i != j:
while nums[j] >= piviot and j > i:
j -= 1
nums[i] = nums[j]
while nums[i] <= piviot and i < j:
i += 1
nums[j] = nums[i]
nums[i] = piviot
sortArray(nums, left, i - 1)
sortArray(nums, i + 1, right)
return sortArray(nums, 0, len(nums) - 1)
上一篇: Js sort排序使用方法_javascript技巧
下一篇: 快速排序原理及代码模板