P1923 【深基9.例4】求第 k 小的数
题目链接
题目思路
利用快排 + 二分来实现分治,从而求得第k小的数
题目代码
快排 + 二分
#include<bits/stdc++.h>
using namespace std;
int q[5000005], k;
void qsort(int l, int r)
{
int i = l, j = r, x = q[(l + r) / 2];
do
{
while(q[j] > x) j -- ;
while(q[i] < x) i ++ ;
if(i <= j)
{
swap(q[i], q[j]);
i ++ , j -- ;
}
}while(i <= j);
if(k <= j) qsort(l, j);
else if(i <= k) qsort(i, r);
else
{
printf("%d\n", q[j + 1]);
exit(0);
}
}
int main()
{
int n;
scanf("%d%d",&n, &k);
for(int i = 0; i < n; i ++ ) scanf("%d", &q[i]);
qsort(0, n - 1);
}
直接快排
#include<bits/stdc++.h>
using namespace std;
int x[5000005],k;
int main()
{
int n;
scanf("%d%d",&n,&k);
for(int i=0;i<n;i++)
scanf("%d",&x[i]);
sort(x,x+n);//快排
printf("%d",x[k]);
}
STL函数
它的用法是 nth_element(a+x,a+x+y,a+x+len);
。
执行之后数组 下标 到 的元素都小于 ,下标 到 的元素 都大于 ,但不保证数组有序。此时 就是数组区间 到 中第 小的数,当然也可以自己定义 函数。
#include<bits/stdc++.h>
using namespace std;
int x[5000005],k;
int main()
{
int n;
scanf("%d%d",&n,&k);
for(int i=0;i<n;i++)
scanf("%d",&x[i]);
nth_element(x,x+k,x+n);//简短又高效
printf("%d",x[k]);
}
作者:vacilie
出处:https://www.cnblogs.com/vacilie/p/16010500.html
版权:本作品采用「署名-非商业性使用-相同方式共享 4.0 国际」许可协议进行许可。
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 终于写完轮子一部分:tcp代理 了,记录一下
· 震惊!C++程序真的从main开始吗?99%的程序员都答错了
· 别再用vector<bool>了!Google高级工程师:这可能是STL最大的设计失误
· 单元测试从入门到精通
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理