voidquick_sort(int q[], int l, int r)
{
if (l >= r) return; //如果区间里面只有一个数或者没有数,那么就不用排序了。int i = l - 1, j = r + 1, x = q[l + r >> 1];
while (i < j)
{
do i ++ ; while (q[i] < x);
do j -- ; while (q[j] > x);
if (i < j) swap(q[i], q[j]);
}
quick_sort(q, l, j), quick_sort(q, j + 1, r);
}
3. 题目
地址:https://www.acwing.com/problem/content/787/
#include<iostream>#include<cstdio>
using namespace std;
voidquick_sort(int q[],int l,int r){
if(l>=r){
return;
}
int i = l-1;
int j = r+1;
int x = q[(l+r) >> 1];
while(i < j){
do{i++;}while(q[i] < x);
do{j--;}while(q[j] > x);
if(i < j){
int temp = q[i];
q[i] = q[j];
q[j] = temp;
}
}
quick_sort(q,l,j);
quick_sort(q,j+1,r);
}
intmain(){
int n;
int q[100010];
scanf("%d",&n);
for(int i=0;i<n;i++){
scanf("%d",&q[i]);
}
quick_sort(q,0,n-1);
for(int i=0;i<n;i++){
printf("%d ",q[i]);
}
return0;
}
地址:https://www.acwing.com/problem/content/788/
#include<iostream>#include<cstdio>
using namespace std;
voidquick_sort(int q[],int l,int r){
if(l >= r){
return;
}
int i = l-1;
int j = r+1;
int x = q[(l+r)>>1];
while(i < j){
do{i++;}while(q[i] < x);
do{j--;}while(q[j] > x);
if(i < j){
int temp = q[i];
q[i] = q[j];
q[j] = temp;
}
}
quick_sort(q,l,j);
quick_sort(q,j+1,r);
}
intmain(){
int n,k;
int q[100010];
scanf("%d %d",&n,&k);
for(int i=0;i<n;i++){
scanf("%d",&q[i]);
}
quick_sort(q,0,n-1);
printf("%d",q[k-1]);
return0;
}
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 分享4款.NET开源、免费、实用的商城系统
· 全程不用写代码,我用AI程序员写了一个飞机大战
· MongoDB 8.0这个新功能碉堡了,比商业数据库还牛
· 白话解读 Dapr 1.15:你的「微服务管家」又秀新绝活了
· 上周热点回顾(2.24-3.2)