C++实现吊桥木头放置数量及总宽度计算
### 🍃思路分析 本题需要根据给定的条件,依次判断每根木头是否可以放到吊桥上,即木头长度需大于等于 5,并且当木头宽度总和达到 10 时停止摆放。通过循环遍历每根木头,统计可放置的木头数量和总宽度。 ### 💻代码实现 ```cpp #include <iostream> using namespace std; int main() { int n; cin >> n; // 读取木头的数量 int count = 0; // 记录放到吊桥上的木头数量 int totalWidth = 0; // 记录放到吊桥上的木头总宽度 for (int i = 0; i < n; ++i) { int length, width; cin >> length >> width; // 读取每根木头的长度和宽度 // 判断木头长度是否大于等于 5 且总宽度小于 10 if (length >= 5 && totalWidth + width <= 10) { count++; totalWidth += width; } } cout << count << " " << totalWidth << endl; // 输出结果 return 0; } ``` ### 📋代码解释 1. **输入处理**:首先读取木头的数量 `n`,然后使用 `for` 循环依次读取每根木头的长度和宽度。 2. **条件判断**:对于每根木头,检查其长度是否大于等于 5,并且总宽度加上当前木头的宽度是否小于等于 10。如果满足条件,则将该木头放到吊桥上,更新木头数量和总宽度。 3. **输出结果**:循环结束后,输出放到吊桥上的木头数量和总宽度。 ### ⚙️复杂度分析 - **时间复杂度**:$O(n)$,其中 $n$ 是木头的数量。因为只需要遍历一次所有的木头。 - **空间复杂度**:$O(1)$,只使用了常数级的额外空间。 ### 💡开发建议 - **输入验证**:可以添加输入验证,确保输入的木头数量和长度、宽度都是合法的正整数。 - **错误处理**:当输入不符合要求时,给出相应的错误提示,增强程序的健壮性。 - **代码复用**:可以将判断木头是否可放置的逻辑封装成一个函数,提高代码的复用性。 ### 📚学习资源 - [C++ 官方文档](https://en.cppreference.com/w/):提供了 C++ 语言的详细文档和示例。 - 《C++ Primer》:经典的 C++ 学习书籍,适合初学者和有一定基础的开发者。 ######[AI写代码神器 | 618点数解答 | 2026-03-20 19:20:19]
- 易语言读取文本文件并显示到超级列表框:代码示例与注意要点(DeepSeek | 571点数解答 | 2025-08-23 20:54:40)221
- 易语言:读取并显示特定文本到超级列表框,还能增加新数据的方法与要点(DeepSeek | 1317点数解答 | 2025-08-23 20:58:40)228
- mallshop商城网站:数据库设计与强大业务功能全揭秘(GPT | 257点数解答 | 2024-12-09 14:08:15)273
- Python 实现球类:精准计算半径、表面积与体积,附输入验证与异常处理!(阿里通义 | 261点数解答 | 2024-11-28 21:19:39)342
- 51 单片机:定时器 0 实现 8 个 LED 循环点亮,附代码及优化建议(字节豆包 | 1193点数解答 | 2024-12-27 15:10:29)309
- C++ 代码实现自定义运算 x@y = x² + y² - xy 及 x@(x+y) 计算(DeepSeek | 215点数解答 | 2025-12-13 15:08:14)64
- C++ 实现根据输入正整数奇偶性计算偶数和或约数和(字节豆包 | 838点数解答 | 2026-02-28 20:23:59)24
- 用Python处理商品销售数据:替换类别、合并类目并输出前5行(百度文心 | 486点数解答 | 2024-08-23 09:14:21)309
- Python 破解:计算序列中满足特定取余条件元素的数量(字节豆包 | 174点数解答 | 2025-05-13 21:29:55)185
- 一文搞定!无名杀“再生安瓿”技能代码全解析及注意事项(字节豆包 | 464点数解答 | 2025-06-15 20:06:30)159
- C# 实现商品类:数量限制 100 及开发注意要点(字节豆包 | 737点数解答 | 2025-09-03 14:44:56)99
- 易语言多线程实战:获取进程信息、读写内存与多线程协同操作(字节豆包 | 790点数解答 | 2025-11-28 03:08:24)38