C++实现查找序列中第k大与第k小元素
### 🍭问题分析 要找到序列中第 `k` 大的元素和第 `k` 小的元素,我们可以先对序列进行排序,然后根据排序后的结果直接获取第 `k` 大(从后往前数第 `k` 个)和第 `k` 小(从前往后数第 `k` 个)的元素。 ### 💻代码实现 ```cpp #include <iostream> #include <vector> #include <algorithm> int main() { int n, k; // 读取 n 和 k std::cin >> n >> k; std::vector<int> a(n); // 读取序列元素 for (int i = 0; i < n; ++i) { std::cin >> a[i]; } // 对序列进行排序 std::sort(a.begin(), a.end()); // 第 k 小的元素 int kthSmallest = a[k - 1]; // 第 k 大的元素 int kthLargest = a[n - k]; // 输出结果 std::cout << kthLargest << " " << kthSmallest << std::endl; return 0; } ``` ### 📝代码解释 1. **输入读取**:首先读取 `n` 和 `k`,然后读取 `n` 个正整数存储在 `vector` 中。 2. **排序**:使用 `std::sort` 函数对 `vector` 进行排序,默认是升序排序。 3. **获取第 `k` 小和第 `k` 大的元素**:排序后,第 `k` 小的元素是 `a[k - 1]`,第 `k` 大的元素是 `a[n - k]`。 4. **输出结果**:将第 `k` 大的元素和第 `k` 小的元素输出,中间用空格分隔。 ### 🚀开发建议 - **错误处理**:可以添加输入验证,确保 `k` 的值在合法范围内(`1 <= k <= n`),避免出现越界错误。 - **性能优化**:如果 `n` 非常大,排序的时间复杂度是 $O(n log n)$,可以使用快速选择算法,将时间复杂度优化到 $O(n)$。 ### 📚学习资源 - [C++ 官方文档](https://en.cppreference.com/w/):提供了 C++ 标准库的详细文档和示例。 - 《C++ Primer》:一本经典的 C++ 学习书籍,适合初学者和有一定基础的开发者。 ######[AI写代码神器 | 625点数解答 | 2026-05-24 16:01:05]
- 求解特定条件下整数序列的最小值:算法分析与代码实现(字节豆包 | 746点数解答 | 2026-01-24 13:14:40)80
- Python 实现球类:精准计算半径、表面积与体积,附输入验证与异常处理!(阿里通义 | 261点数解答 | 2024-11-28 21:19:39)397
- 51 单片机:定时器 0 实现 8 个 LED 循环点亮,附代码及优化建议(字节豆包 | 1193点数解答 | 2024-12-27 15:10:29)364
- iOS开发揭秘:序列(Sequence)索引是否从0开始?实例为你解答!(百度文心 | 187点数解答 | 2023-11-09 17:44:38)261
- jQuery 实现动态操作 DOM:打造可增删任务的待办事项列表应用(百度文心 | 1015点数解答 | 2024-10-26 23:41:22)459
- MATLAB实现r5(n)序列离散傅立叶变换及补零至20长序列DFT计算 (GPT | 339点数解答 | 2024-10-28 16:31:47)301
- jQuery 打造实用待办事项列表:输入添加、点击删除一步到位!(阿里通义 | 1139点数解答 | 2024-10-29 08:44:48)377
- jQuery 实现动态操作 DOM:打造带添加与删除功能的待办事项列表应用(阿里通义 | 687点数解答 | 2024-10-29 09:25:06)389
- 求解整数序列操作最小次数:让前缀和之和等于后缀和之和(DeepSeek | 1329点数解答 | 2025-05-25 17:27:01)248
- C++求解:使整数序列前缀和之和等于后缀和之和的最小操作次数(DeepSeek | 532点数解答 | 2025-05-25 17:27:47)276
- 32位二进制IP地址转点分十进制:Python代码实现及示例(DeepSeek | 102点数解答 | 2026-01-20 13:53:38)64
- C++:轻松判断 int 型整数 32 位内码是否对称,附代码详解!(字节豆包 | 560点数解答 | 2026-01-23 19:44:43)51