C/C++教程

排序-quicksort

本文主要是介绍排序-quicksort,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!

int randpartion(vector<int>& input,int l,int r,int k){
        int now =  rand() %(r-l+1) + l;
        swap(input[now],input[r]);
        int j = l-1;
        for(int i=l;i<r;++i){
            if(input[i]<input[r]){
                swap(input[++j],input[i]);
            }
        }
        swap(input[j+1],input[r]);
        return j+1;
    }
    void quicksort(vector<int>& input,int l,int r,int k){
        int now = randpartion(input,l,r,k);
       quicksort(input,now+1,r,k);
        quicksort(input,l,now-1,k);
    }

 

最小k,第k大

int randpartion(vector<int>& input,int l,int r,int k){
        int now =  rand() %(r-l+1) + l;
        swap(input[now],input[r]);
        int j = l-1;
        for(int i=l;i<r;++i){
            if(input[i]<input[r]){
                swap(input[++j],input[i]);
            }
        }
        swap(input[j+1],input[r]);
        return j+1;
    }
    void quicksort(vector<int>& input,int l,int r,int k){
        int now = randpartion(input,l,r,k);
        if(now==k-1) return ;
        else if(now<k) quicksort(input,now+1,r,k);
        else quicksort(input,l,now-1,k);
    }

这篇关于排序-quicksort的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!