Leetcode——快速排序

题目描述:

给你一个整数数组 nums,请你将该数组升序排列。
在这里插入图片描述


个人思路:

我们先来说一下快速排序的基本思想。

  1. 先从数组中找一个基准数

  2. 让其他比它大的元素移动到数列一边,比他小的元素移动到数列另一边,从而把数组拆解成两个部分。

  3. 再对左右区间重复第二步,直到各区间只有一个数。

这里特别注意随机数的生成,如果是普通快排是超时的,我猜测是因为测试样例中有卡O(n^2),因为我用冒泡的结果与普通快排的结果差不多,所以要用到随机快排。随即快排与普通快排,代码体现出来就是加了两行代码。

普通快排的意思就是每次主元默认选择左边界。

总结就是考虑这么一种情况,一万个倒序排放的数字序列,如果用普通快排的话,那么其比较次数的后果导致的时间复杂度是O(n^2),所以就会超时,而如果用随机快排的话,其时间复杂度依旧是O(nlogn)。


普通快排:

void quick_sort(vector<int>& nums, int l, int r){
        if(l < r) 
        {   
            int i = l, j = r, x = nums[i];
            while(i < j){
                while(i < j && nums[j] >= x) j--;
                if(i < j) nums[i] = nums[j];
                while(i < j && nums[i] < x) i++;
                if(i < j) nums[j] = nums[i];
            }
            nums[i] = x;
            quick_sort(nums, l, i - 1);
            quick_sort(nums, i + 1, r);
        }
    }

随机快排:

void quick_sort(vector<int>& nums, int l, int r){
        if(l < r) 
        {   
            int s = rand()% (r-l+1) + l;
            swap(nums[l], nums[s]);
            
            int i = l, j = r, x = nums[i];
            while(i < j){
                while(i < j && nums[j] >= x) j--;
                if(i < j) nums[i] = nums[j];
                while(i < j && nums[i] < x) i++;
                if(i < j) nums[j] = nums[i];
            }
            nums[i] = x;
            quick_sort(nums, l, i - 1);
            quick_sort(nums, i + 1, r);
        }
    }
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值