计算分组乘船最重重量和的代码实现
```cpp #include <iostream> #include <algorithm> using namespace std; int a[100], n, ans = 0; int main() { cin >> n; for (int i = 1; i <= n; i++) { cin >> a[i]; } // 排序 sort(a + 1, a + n + 1); // 求所有船的重量并求最大值 for (int i = 1; i <= n / 2; i++) { int currentWeight = a[i] + a[n - i + 1]; if (currentWeight > ans) { ans = currentWeight; } } cout << ans; return 0; } ``` ### 代码解释 1. **读取输入**:程序首先读取人数 `n` 以及每个人的体重,将体重存储在数组 `a` 中。 2. **排序**:使用 `sort` 函数对数组 `a` 进行排序,排序范围是从 `a[1]` 到 `a[n]`,使得数组元素按从小到大的顺序排列。 3. **计算每艘船的重量并找出最大值**:根据提示,第 `i` 个人与第 `n - i + 1` 个人一组。通过循环遍历 `i` 从 `1` 到 `n/2`,计算每组两人的体重和 `currentWeight`,并与当前记录的最大值 `ans` 比较,如果 `currentWeight` 大于 `ans`,则更新 `ans`。 4. **输出结果**:最后输出最重的一艘船上两人的重量和 `ans`。 ### 复杂度分析 - **时间复杂度**:排序操作的时间复杂度为 $O(n log n)$,后续遍历数组计算重量和的时间复杂度为 $O(n/2)$,整体时间复杂度主要由排序决定,为 $O(n log n)$。 - **空间复杂度**:只使用了常数级的额外空间,空间复杂度为 $O(1)$。 ######[AI问答 | 485点数解答 | 2026-03-28 20:14:08]
- Python 实现球类:精准计算半径、表面积与体积,附输入验证与异常处理!(阿里通义 | 261点数解答 | 2024-11-28 21:19:39)346
- 51 单片机:定时器 0 实现 8 个 LED 循环点亮,附代码及优化建议(字节豆包 | 1193点数解答 | 2024-12-27 15:10:29)316
- 用 JS 中 for 循环实现 1 到 100 相加并输出结果到页面的完整代码 ( | 240点数解答 | 2024-05-20 22:11:29)467
- 用 JS 的 while 循环实现 1 到 100 相加并输出到页面的代码揭秘( | 47点数解答 | 2024-05-20 22:16:48)357
- C++ 代码实现自定义运算 x@y = x² + y² - xy 及 x@(x+y) 计算(DeepSeek | 215点数解答 | 2025-12-13 15:08:14)75
- C++ 实现根据输入正整数奇偶性计算偶数和或约数和(字节豆包 | 838点数解答 | 2026-02-28 20:23:59)28
- C++ 编程:根据规则精准计算包裹邮寄费用,附代码详解(DeepSeek | 506点数解答 | 2025-02-28 11:06:32)431
- C++实现邮局包裹费用计算:避开边界、输入及逻辑陷阱!(字节豆包 | 355点数解答 | 2025-11-23 11:41:12)41
- C++实现:根据邮局包裹规定计算邮寄费用或判断无法邮寄(字节豆包 | 256点数解答 | 2025-11-23 11:54:36)39
- 邮局包裹邮寄费用计算程序:开发要点与代码实现(字节豆包 | 272点数解答 | 2025-12-17 11:39:32)51
- 邮寄包裹费用计算程序:避开边界、精度与输入陷阱!(DeepSeek | 143点数解答 | 2026-01-29 16:53:28)33
- Python程序:根据包裹重量算邮寄费用,超30千克不予邮寄!(字节豆包 | 168点数解答 | 2026-01-29 16:57:06)27