排序-quicksort
2022/3/3 23:45:16
本文主要是介绍排序-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的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!
- 2024-06-29易优CMS安装常见问题汇总-icode9专业技术文章分享
- 2024-06-28易优新手必读安装教程-icode9专业技术文章分享
- 2024-06-28忘记eyoucms后台密码怎么办?-icode9专业技术文章分享
- 2024-06-26终极指南:Scrum中如何设置需求优先级
- 2024-06-26AI大模型企业应用实战(25)-为Langchain Agent添加记忆功能
- 2024-06-26小白家庭 nas 搭建方案-icode9专业技术文章分享
- 2024-06-23AI大模型企业应用实战(14)-langchain的Embedding
- 2024-06-23AI大模型企业应用实战(15)-langchain核心组件
- 2024-06-23AI大模型企业应用实战(16)-langchain核心组件
- 2024-06-23AI 大模型企业应用实战(06)-初识LangChain