
























GESP C++四级练习(三级也可以尝试),排序与去重练习,难度⭐⭐。
现有 $n$ 个正整数,要求出这 $n$ 个正整数中的第 $k$ 个最小整数(相同大小的整数只计算一次)。
第一行为 $n$ 和 $k$; 第二行开始为 $n$ 个正整数的值,整数间用空格隔开。
第 $k$ 个最小整数的值;若无解,则输出
NO RESULT。
1
2
10 3
1 3 3 7 2 5 1 2 4 6
$n \leq 10000$,$k \leq 4000$,正整数均小于 $30000$。
本题要求在 $n$ 个正整数中,找到去重后的第 $k$ 小的整数。核心操作是排序和去重。
NO RESULTNO RESULT。std::sort 对数组进行排序a[i] != a[i-1] 时计数器加一复杂度分析:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
#include <algorithm>
#include <iostream>
int main() {
int n, k;
std::cin >> n >> k;
// 读入 n 个正整数
int a[10001];
for (int i = 0; i < n; i++) {
std::cin >> a[i];
}
// 从小到大排序
std::sort(a, a + n);
// 排序后第一个元素就是第 1 小的整数
int count = 1;
// 如果 k 为 1,直接输出排序后的第一个元素
if (count == k) {
std::cout << a[0] << std::endl;
return 0;
}
// 从第二个元素开始遍历,遇到不同的值则计数加一
for (int i = 1; i < n; i++) {
if (a[i] != a[i - 1]) {
count++;
if (count == k) {
std::cout << a[i] << std::endl;
return 0;
}
}
}
// 遍历结束仍未找到第 k 小的整数,输出无解
std::cout << "NO RESULT" << std::endl;
return 0;
}
所有代码已上传至Github:https://github.com/lihongzheshuai/yummy-code
GESP 学习专题站:GESP WIKI
"luogu-"系列题目可在洛谷题库进行在线评测。
"bcqm-"系列题目可在编程启蒙题库进行在线评测。
欢迎加入:Java、C++、Python技术交流QQ群(982860385),大佬免费带队,有问必答
欢迎加入:C++ GESP/CSP认证学习QQ频道,考试资源总结汇总
欢迎加入:C++ GESP/CSP学习交流QQ群(688906745),考试认证学员交流,互帮互助
此内容由惯性聚合(RSS阅读器)自动聚合整理,仅供阅读参考。 原文来自 — 版权归原作者所有。