C++ 实现找出闪点裂隙最大五个不重复传送距离
以下是实现该功能的 C++ 代码: ```cpp #include <iostream> #include <algorithm> #include <vector> #include <set> int main() { int n; // 读取闪点裂隙的个数 std::cin >> n; std::vector<int> distances(n); // 读取每个闪点裂隙的传送距离 for (int i = 0; i < n; ++i) { std::cin >> distances[i]; } // 使用 set 自动去重并排序 std::set<int, std::greater<int>> uniqueDistances(distances.begin(), distances.end()); int sum = 0; for (auto it = uniqueDistances.begin(); it != uniqueDistances.end(); ++it) { if (sum > 0) { std::cout << " "; } std::cout << *it; sum++; if (sum == 5) { break; } } std::cout << std::endl; return 0; } ``` ### 代码解释: 1. **读取输入**:首先读取闪点裂隙的个数 `n`,然后读取 `n` 个整数,表示每个闪点裂隙的传送距离,存储在 `distances` 向量中。 2. **去重和排序**:使用 `std::set` 来自动对输入的距离进行去重和排序,`std::set` 会自动按照从大到小的顺序存储元素。 3. **输出结果**:遍历 `std::set`,输出最大的五个不重复的数,如果不足五个数,则输出所有数。使用 `sum` 变量记录已经输出的数的个数,当 `sum` 等于 5 时,停止输出。 ### 复杂度分析: - **时间复杂度**:$O(n log n)$,主要是 `std::set` 的插入操作的时间复杂度。 - **空间复杂度**:$O(n)$,主要是 `std::set` 的空间开销。 ######[AI问答 | 484点数解答 | 2026-05-16 20:24:56]
- 易语言代码优化:自动出售物资子程序整合与优化全解析(DeepSeek | 2181点数解答 | 2025-07-23 10:26:29)245
- Python 实现球类:精准计算半径、表面积与体积,附输入验证与异常处理!(阿里通义 | 261点数解答 | 2024-11-28 21:19:39)390
- 高考毕业晚会难题:从学生能力值求最大默契程度的Python解法(字节豆包 | 487点数解答 | 2026-01-24 13:10:18)63
- Matlab 实现遗传算法求解图最短路径:参数设置与关键操作解析(字节豆包 | 128点数解答 | 2024-11-25 02:48:03)216
- MATLAB代码:修正遗传算法初始化种群代码,解决潜在错误(字节豆包 | 360点数解答 | 2024-11-25 02:48:49)209
- C++代码实现计算骑行总时间及详细解析(字节豆包 | 460点数解答 | 2026-03-03 19:51:23)38
- 51 单片机:定时器 0 实现 8 个 LED 循环点亮,附代码及优化建议(字节豆包 | 1193点数解答 | 2024-12-27 15:10:29)359
- Python程序:多人物9参数雷达图生成,参数折合百分制展示(字节豆包 | 873点数解答 | 2026-01-11 21:07:42)60
- C++实现多对象9参数雷达图绘制:输入满值后自动折合百分制(字节豆包 | 801点数解答 | 2026-01-11 21:09:16)66
- Python实现:多人员9参数雷达图生成程序,自由添加人员并折算分数(字节豆包 | 467点数解答 | 2026-01-11 21:10:04)47
- 用 Pandas 深度剖析数据:从读取到统计分析全流程实战(GPT | 642点数解答 | 2024-06-30 15:39:49)384
- 用 Pandas 深入分析招聘数据:从数据读取到可视化全流程解析(GPT | 1539点数解答 | 2024-06-30 15:56:50)409