leetcode----快速排序

原理介绍
假设我们需要对数组Array=[2,5,1,3,7,6,4]进行排序。首先我们把数组第一个元素作为基准数。然后,我们从右向左分别与基准数比较,找到比基准数小的索引;再从左向右分别于基准数比较,找到比基准数大的索引。找到两个索引后,对调两索引的元素。举例子,我们看Array,把左右两边数的索引分别设为i=1,j=len(Array)-1,从右往左与2作比较,发现1小于2,再从左往右,发现5大于2,因此对调两数。

Array = [2,1,5,3,7,6,4]

此时i=1,j=2,继续在此索引下重复上述操作,即从j=2往左找小于基准数的数,发现1小于2,但是此时i,j相交,说明在索引为1的位置上,数字2左边的数均小于它,右边的数都大于它。所以,我们就找到了2在Array中顺序排序的索引位置。我们将Aarry[i=1]与2对调位置。

Array=[1,2,5,3,7,6,4]

此时,我们发现2把数组分成了左右两边。因此,我们对左右两边的数组继续进行上述操作。

Array1 = [1]
Array1只有一个元素,它不需要排序,因此,我们把数组个数为1作为结束标志。

Array2=[5,3,7,6,4]
把5作为基准数,从右往左比较,发现4小于5,从左往右,发现7大于5,因此对调i=2,j=4。

Array2=[5,3,4,6,7]
继续从j=4往右比较,发现4小于5,此时,j=2与i=2相遇。因此,判断5在索引为2的位置时,其左均小于5,右均大于5。调换i=2,与基准数的位置。

Array2 = [4,3,5,6,7]
因为只有个数为1的数组,我们才认为有序。故,继续把Array2分为两个数组Array3=[4,3],Array4=[6,7]

Array3=[4,3]
基准数是4,从右往左发现3小于4,但是i与j相遇,因此,直接对调i=1与4的位置,得到Array3=[3,4]. 同样Array4也是如此。

最后,我们获得顺序序列Array=[1,2,3,4,5,6,7]

代码

class Solution:
    def randomized_partition(self, nums, l, r):
       i = l
       j = r
       temp = nums[l]
       while(i !=j):
           while(nums[j] >= temp and i<j):
               j = j - 1
           while(nums[i] <= temp and i<j):
               i = i + 1
           if(i < j):
               nums[i], nums[j] = nums[j], nums[i]
       nums[l], nums[i] = nums[i], nums[l]
       return i

    def randomized_quicksort(self, nums, l, r):
        if r - l <= 0:
            return
        mid = self.randomized_partition(nums, l, r)
        self.randomized_quicksort(nums, l, mid - 1)
        self.randomized_quicksort(nums, mid + 1, r)

    def sortArray(self, nums):
        self.randomized_quicksort(nums, 0, len(nums) - 1)
        return nums

a = [2,5,1,3,7,6,4]
b = Solution()
print(b.sortArray(a))
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值