第k个数(题解)

举报
irrational 发表于 2022/01/19 00:42:10 2022/01/19
【摘要】 给定一个长度为n的整数数列,以及一个整数 k,请用快速选择算法求出数列从小到大排序后的第k个数。 输入格式 第一行包含两个整数n和k。 第二行包含n个整数(所有整数均在1~10^9范围内),表示整数数列。 输出格式 输出一个整数,表示数列的第k小数。 数据范围 1<n≤100000,1<k≤n 输入样例: 5 3...

给定一个长度为n的整数数列,以及一个整数 k,请用快速选择算法求出数列从小到大排序后的第k个数。
输入格式
第一行包含两个整数n和k。
第二行包含n个整数(所有整数均在1~10^9范围内),表示整数数列。
输出格式
输出一个整数,表示数列的第k小数。
数据范围
1<n≤100000,1<k≤n

输入样例:


  
  1. 5 3
  2. 2 4 1 5 3

输出样例:

3

 

  
  1. #include <iostream>
  2. using namespace std;
  3. const int N = 100010;
  4. int q[N];
  5. int quick_sort(int q[], int l, int r, int k)
  6. {
  7. if (l >= r) return q[l];
  8. int i = l - 1, j = r + 1, x = q[l + r >> 1];
  9. while (i < j)
  10. {
  11. do i ++ ; while (q[i] < x);
  12. do j -- ; while (q[j] > x);
  13. if (i < j) swap(q[i], q[j]);
  14. }
  15. if (j - l + 1 >= k) return quick_sort(q, l, j, k);
  16. else return quick_sort(q, j + 1, r, k - (j - l + 1));
  17. }
  18. int main()
  19. {
  20. int n, k;
  21. scanf("%d%d", &n, &k);
  22. for (int i = 0; i < n; i ++ ) scanf("%d", &q[i]);
  23. cout << quick_sort(q, 0, n - 1, k) << endl;
  24. return 0;
  25. }

 说实话,我觉得这个题目意义不大了,不就是要第k个吗?我一手直接sort然后输出第k个。

文章来源: blog.csdn.net,作者:irrationality,版权归原作者所有,如需转载,请联系作者。

原文链接:blog.csdn.net/weixin_54227557/article/details/120592890

【版权声明】本文为华为云社区用户转载文章,如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

评论(0

0/1000
抱歉,系统识别当前为高风险访问,暂不支持该操作

全部回复

上滑加载中

设置昵称

在此一键设置昵称,即可参与社区互动!

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。