排序-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);
}
标签:排序,int,quicksort,vector,swap,input,now 来源: https://www.cnblogs.com/fengzlj/p/15962452.html