C++计算分组乘船最重重量和的实现与开发建议
### 🍃解题思路 根据题目要求,我们需要先将所有人的体重进行排序,然后将最重的和最轻的分为一组,第二重的和第二轻的分为一组,以此类推。最后找出所有组中重量和最大的那一组的重量和。 ### 💻代码实现 ```cpp #include <iostream> #include <algorithm> using namespace std; int main() { int n; // 读取人数 cin >> n; int weights[100]; // 读取每个人的体重 for (int i = 0; i < n; i++) { cin >> weights[i]; } // 对体重进行排序 sort(weights, weights + n); int maxWeight = 0; // 遍历分组,计算每组的重量和,并找出最大值 for (int i = 0; i < n / 2; i++) { int currentWeight = weights[i] + weights[n - i - 1]; if (currentWeight > maxWeight) { maxWeight = currentWeight; } } // 输出最重的一组的重量和 cout << maxWeight << endl; return 0; } ``` ### 📋代码解释 1. **输入处理**:首先读取人数`n`,然后读取每个人的体重并存储在数组`weights`中。 2. **排序**:使用`sort`函数对数组`weights`进行排序,将体重从小到大排列。 3. **分组计算**:通过循环将最重的和最轻的分为一组,第二重的和第二轻的分为一组,以此类推。计算每组的重量和,并找出最大值。 4. **输出结果**:输出最重的一组的重量和。 ### ⚙️复杂度分析 - **时间复杂度**:排序的时间复杂度为$O(n log n)$,遍历分组的时间复杂度为$O(n/2)$,因此总的时间复杂度为$O(n log n)$。 - **空间复杂度**:只使用了一个数组来存储体重,因此空间复杂度为$O(n)$。 ### 🚀开发建议 - **边界检查**:在实际开发中,需要对输入进行边界检查,确保输入的人数`n`为偶数且小于100。 - **错误处理**:可以添加错误处理代码,例如当输入的人数不是偶数时,输出错误信息。 - **代码复用**:可以将分组计算的逻辑封装成一个函数,提高代码的复用性。 ######[AI写代码神器 | 589点数解答 | 2026-03-13 20:20:55]
- Python 实现球类:精准计算半径、表面积与体积,附输入验证与异常处理!(阿里通义 | 261点数解答 | 2024-11-28 21:19:39)338
- 51 单片机:定时器 0 实现 8 个 LED 循环点亮,附代码及优化建议(字节豆包 | 1193点数解答 | 2024-12-27 15:10:29)307
- C++ 代码实现自定义运算 x@y = x² + y² - xy 及 x@(x+y) 计算(DeepSeek | 215点数解答 | 2025-12-13 15:08:14)61
- C++ 实现根据输入正整数奇偶性计算偶数和或约数和(字节豆包 | 838点数解答 | 2026-02-28 20:23:59)22
- C++ 编程:根据规则精准计算包裹邮寄费用,附代码详解(DeepSeek | 506点数解答 | 2025-02-28 11:06:32)422
- C++实现邮局包裹费用计算:避开边界、输入及逻辑陷阱!(字节豆包 | 355点数解答 | 2025-11-23 11:41:12)36
- C++实现:根据邮局包裹规定计算邮寄费用或判断无法邮寄(字节豆包 | 256点数解答 | 2025-11-23 11:54:36)37
- 邮局包裹邮寄费用计算程序:开发要点与代码实现(字节豆包 | 272点数解答 | 2025-12-17 11:39:32)48
- 邮寄包裹费用计算程序:避开边界、精度与输入陷阱!(DeepSeek | 143点数解答 | 2026-01-29 16:53:28)29
- Python程序:根据包裹重量算邮寄费用,超30千克不予邮寄!(字节豆包 | 168点数解答 | 2026-01-29 16:57:06)23
- Python 程序:根据包裹重量计算邮寄费用或判断能否邮寄(字节豆包 | 110点数解答 | 2026-01-29 17:00:41)31
- Python 实现:根据邮局包裹规定计算邮寄费用或判定无法邮寄(字节豆包 | 148点数解答 | 2026-01-29 17:03:26)29