排序算法(归并排序)

//函数主体
void sort(vector<int>& nums){
        //将每一组的个数不断从1到2到小于n的最大值
        int k=1,n=nums.size();
        while(k<n){
            mergesort(nums,k);
            k*=2;
        }
    }
    //该函数对当前的数组根据分组个数进行差分,留出最后的一组或两组单独处理
    void mergesort(vector<int>& nums,int k){
        int n=nums.size(),i=0;
        while(i<=n-2*k){//最后的一组或者两组最后进行处理
            merge(nums,i,i+k,i+2*k);
            i+=2*k;
        }
        if((n-i)>k){//剩两组,需要对剩下两组进行归并
            merge(nums,i,i+k,n);
        }
    }
    //相邻两组归并的具体细节,就是一个排序插入的过程
    void merge(vector<int>& nums,int ll,int mid,int rr){
        vector<int> temp(rr-ll,INT_MIN);
        int a=ll,b=mid,val=0;
        while(a<mid&&b<rr){
            if(nums[a]<nums[b]){
                temp[val++]=nums[a++];
            }
            else{
                temp[val++]=nums[b++];
            } 
        }
        if(temp[rr-ll-1]==INT_MIN){
            if(a==mid){
                while(b<rr){
                    temp[val++]=nums[b++];
                }
            }else{
                while(a<mid){
                    temp[val++]=nums[a++];
                }
            }
        }
        for(int i=0;i<(rr-ll);++i){
            nums[i+ll]=temp[i];
        }
    }

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

yanzhe1

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值