惯性聚合 高效追踪和阅读你感兴趣的博客、新闻、科技资讯
阅读原文 在惯性聚合中打开

推荐订阅源

Simon Willison's Weblog
Simon Willison's Weblog
G
Google Developers Blog
Spread Privacy
Spread Privacy
I
InfoQ
V
V2EX
S
Schneier on Security
小众软件
小众软件
C
CERT Recently Published Vulnerability Notes
博客园 - 聂微东
奇客Solidot–传递最新科技情报
奇客Solidot–传递最新科技情报
Stack Overflow Blog
Stack Overflow Blog
T
Threat Research - Cisco Blogs
L
Lohrmann on Cybersecurity
Recent Announcements
Recent Announcements
Cyber Security Advisories - MS-ISAC
Cyber Security Advisories - MS-ISAC
Attack and Defense Labs
Attack and Defense Labs
云风的 BLOG
云风的 BLOG
The Hacker News
The Hacker News
S
SegmentFault 最新的问题
C
Cybersecurity and Infrastructure Security Agency CISA
NISL@THU
NISL@THU
OSCHINA 社区最新新闻
OSCHINA 社区最新新闻
GbyAI
GbyAI
Latest news
Latest news
S
Secure Thoughts
Project Zero
Project Zero
MongoDB | Blog
MongoDB | Blog
I
Intezer
Security Latest
Security Latest
Apple Machine Learning Research
Apple Machine Learning Research
Vercel News
Vercel News
N
Netflix TechBlog - Medium
V2EX - 技术
V2EX - 技术
量子位
T
Threatpost
T
The Blog of Author Tim Ferriss
Y
Y Combinator Blog
T
Tor Project blog
A
Arctic Wolf
Microsoft Security Blog
Microsoft Security Blog
T
The Exploit Database - CXSecurity.com
大猫的无限游戏
大猫的无限游戏
T
Tailwind CSS Blog
freeCodeCamp Programming Tutorials: Python, JavaScript, Git & More
C
Check Point Blog
博客园 - Franky
Google DeepMind News
Google DeepMind News
The Register - Security
The Register - Security
The GitHub Blog
The GitHub Blog
L
LINUX DO - 热门话题

OneCoder

【GESP】C++二级真题 luogu-B4553 [GESP202606 二级] 完全平方数计数 【GESP】C++一级真题 luogu-B4551 [GESP202606 一级] 去旅行 【GESP】C++一级真题 luogu-B4552 [GESP202606 一级] 交税 【NOIP】2000真题解析 luogu-P1023 税收与补贴问题(适合GESP四、五级以上练习) 【NOIP】2000真题解析 luogu-P1022 计算器的改良(适合GESP四、五级以上练习) 【NOIP】2001真题解析 luogu-P1029 最大公约数和最小公倍数问题 【CSP】CSP-X 2018真题 11的倍数 luogu-B4075 (适合GESP三级及以上考生练习) 【CSP】CSP-X 2018真题 统计成绩 luogu-B4074 (适合GESP二级及以上考生练习) 【CSP】CSP-X 2018真题 快递费用 luogu-B4073 (适合GESP二级及以上考生练习) 【CSP】CSP-X 2018真题 小明的照片 luogu-B4072 (适合GESP一级及以上考生练习) 【NOIP】2008真题解析 luogu-P1125 笨小猴 【信奥业余科普】C++ 的奇妙之旅 29:别让 TLE 和 MLE 偷走你的分——复杂度估算与数据范围速查 【信奥业余科普】C++ 的奇妙之旅 28:规范比赛代码的钥匙——文件操作与输入输出重定向(freopen) 【CSP】CSP-J 2023真题 公路 luogu-P9749 (适合GESP四级及以上考生练习) 【信奥业余科普】C++ 的奇妙之旅 27:高效处理数据的利器——常用算法库(algorithm) 【CSP】CSP-J 2022真题 解密 luogu-P8814 (适合GESP四级及以上考生练习) 【信奥业余科普】C++ 的奇妙之旅 26:高效的键值对——映射(map)与多重映射(multimap) 【CSP】CSP-J 2022真题 乘方 luogu-P8813 (适合GESP二级及以上考生练习) 【信奥业余科普】C++ 的奇妙之旅 25:自动排序的利器——集合(set)与多重集合(multiset) 【CSP】CSP-J 2019真题 纪念品 luogu-P5662 (适合GESP六级及以上考生练习) 【信奥业余科普】C++ 的奇妙之旅 24:拆解 deque——分段连续的双端队列 【信奥业余科普】C++ 的奇妙之旅 23:主动限制的艺术——栈(stack)与队列(queue)
【GESP】C++四级练习 luogu-P1138 第 k 小整数
OneCoder · 2026-06-16 · via OneCoder

GESP C++四级练习(三级也可以尝试),排序与去重练习,难度⭐⭐。

luogu-P1138 第 k 小整数

题目要求

题目描述

现有 $n$ 个正整数,要求出这 $n$ 个正整数中的第 $k$ 个最小整数(相同大小的整数只计算一次)。

输入格式

第一行为 $n$ 和 $k$; 第二行开始为 $n$ 个正整数的值,整数间用空格隔开。

输出格式

第 $k$ 个最小整数的值;若无解,则输出 NO RESULT

输入输出样例 #1

输入 #1

1
2
10 3
1 3 3 7 2 5 1 2 4 6

输出 #1

说明/提示

$n \leq 10000$,$k \leq 4000$,正整数均小于 $30000$。


题目分析

解题思路

本题要求在 $n$ 个正整数中,找到去重后的第 $k$ 小的整数。核心操作是排序去重

  1. 问题分析:
    • 输入 $n$ 个正整数,其中可能包含重复元素
    • 需要在去除重复元素后,找到第 $k$ 小的整数
    • 如果去重后不足 $k$ 个不同的整数,输出 NO RESULT
  2. 解题方法:
    • 排序:首先将 $n$ 个正整数从小到大排序。排序后,相同的元素会紧邻在一起,方便后续去重操作。
    • 遍历去重并计数:排序完成后,从头到尾遍历数组。遍历过程中,每遇到一个与前一个元素不同的值,就表示找到了一个新的不重复整数,将计数器加一。当计数器达到 $k$ 时,当前元素即为答案。
    • 无解判断:如果遍历完整个数组后,计数器仍未达到 $k$,则说明不同整数的总数不足 $k$ 个,输出 NO RESULT
  3. 实现要点:
    • 使用 std::sort 对数组进行排序
    • 排序后第一个元素天然是第 1 小的,因此计数器从 1 开始
    • 从第二个元素开始遍历,每当 a[i] != a[i-1] 时计数器加一
    • 注意数组大小需根据数据范围定义($n \leq 10000$)

复杂度分析:

  • 时间复杂度:$O(n \log n)$,排序是主要的时间开销
  • 空间复杂度:$O(n)$,需要存储 $n$ 个整数

示例代码

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),考试认证学员交流,互帮互助

GESP/CSP 认证学习微信公众号

GESP/CSP 认证学习微信公众号