快速排序原理及实现

快速排序的步骤:

  1. 从数组中选择一个基准数(选择哪一个没有关系,为了方便一般选第一个或者最后一个,也可以随机选择)。
  2. 把小于基准数的数移动到基准数左边,大于基准数的数移动到基准数右边,和基准值相同的数可以放到任意一边。此时,基准数左边的所有值都小于右边的任意值。
  3. 对于左右两边的子数组,重复以上操作,直到数组有序。

如果可以开辟新数组保存结果,用python可以很快地写出代码。但如果要求不使用额外数组空间、在原地完成排序,应该怎么办呢?(面试、考试一般都要求这样)对于第二步,历史上曾提出过许多种方法,在现在刷题时不同的人也会使用不同的方法。

下面介绍一个比较常见的交换法,仅仅看很难理解其中的原理,自己画图走一遍将会恍然大悟!

  1. 选择数组的第一个元素a[0]作为pivot,设置两个指针,i指向最左边的元素a[0]j指向最右边的元素a[n-1]
  2. 比较a[j]pivot,当a[j] >= pivotj指针向左移动一位,直到a[j] < pivot
  3. a[j]填到a[i]
  4. 比较a[i]pivot,当a[i] <= pivotleft指针向右移动一位,直到a[i] > pivot
  5. a[i]填到a[j]
  6. 不断重复2、3、4、5步骤
  7. i指针和j指针重合时,令a[i] = pivot,此时pivot的左边所有元素都小于等于pivot,右边所有元素都大于等于pivot
  8. 对于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)
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值