计算序列中第k大与第k小数的差值
### 📝 解题思路 要解决这个问题,我们需要找到序列中第 `k` 大的数和第 `k` 小的数,然后计算它们的差值。由于题目中明确提示可以先使用排序,我们可以直接对数组进行排序,然后通过索引找到对应的值。 ### 💻 代码实现 ```cpp #include <iostream> #include <algorithm> using namespace std; int main() { int n, k; cin >> n >> k; int sequence[n]; for (int i = 0; i < n; ++i) { cin >> sequence[i]; } // 排序数组 sort(sequence, sequence + n); // 第k小的数是 sequence[k - 1] // 第k大的数是 sequence[n - k] int kth_min = sequence[k - 1]; int kth_max = sequence[n - k]; // 计算差值 int result = kth_max - kth_min; cout << result << endl; return 0; } ``` ### 📌 代码解释 1. **输入处理**: - 首先读取输入的整数 `n` 和 `k`。 - 然后读取长度为 `n` 的序列,存储在数组 `sequence` 中。 2. **排序**: - 使用 `sort` 函数对数组 `sequence` 进行升序排序。 3. **查找第 `k` 小的数和第 `k` 大的数**: - 第 `k` 小的数在排序后的数组中位于索引 `k - 1`。 - 第 `k` 大的数在排序后的数组中位于索引 `n - k`。 4. **计算差值**: - 计算第 `k` 大的数减去第 `k` 小的数的差值,并输出结果。 ### 📚 示例运行 **输入1**: ``` 3 1 5 1 3 ``` **输出1**: ``` 4 ``` **输入2**: ``` 5 2 3 2 5 1 4 ``` **输出2**: ``` 2 ``` ######[AI问答 | 537点数解答 | 2026-05-31 21:45:34]
- Java 实现:从点类到圆类,计算圆心坐标(50,30)、半径 4 的圆周长与面积(字节豆包 | 246点数解答 | 2024-11-11 16:36:30)365
- 求解特定条件下整数序列的最小值:算法分析与代码实现(字节豆包 | 746点数解答 | 2026-01-24 13:14:40)82
- Python:轻松提取10.0到99.0小数的整数部分(字节豆包 | 136点数解答 | 2026-01-11 19:23:18)61
- iOS开发揭秘:序列(Sequence)索引是否从0开始?实例为你解答!(百度文心 | 187点数解答 | 2023-11-09 17:44:38)263
- MATLAB实现r5(n)序列离散傅立叶变换及补零至20长序列DFT计算 (GPT | 339点数解答 | 2024-10-28 16:31:47)303
- 求解整数序列操作最小次数:让前缀和之和等于后缀和之和(DeepSeek | 1329点数解答 | 2025-05-25 17:27:01)248
- C++求解:使整数序列前缀和之和等于后缀和之和的最小操作次数(DeepSeek | 532点数解答 | 2025-05-25 17:27:47)277
- 32位二进制IP地址转点分十进制:Python代码实现及示例(DeepSeek | 102点数解答 | 2026-01-20 13:53:38)65
- C++:轻松判断 int 型整数 32 位内码是否对称,附代码详解!(字节豆包 | 560点数解答 | 2026-01-23 19:44:43)53
- C++ 代码实现自定义运算 x@y = x² + y² - xy 及 x@(x+y) 计算(DeepSeek | 215点数解答 | 2025-12-13 15:08:14)111
- C++ 实现根据输入正整数奇偶性计算偶数和或约数和(字节豆包 | 838点数解答 | 2026-02-28 20:23:59)80
- 解决代码WA问题:修改整数溢出问题后的计算代码(字节豆包 | 749点数解答 | 2026-05-10 16:20:03)28