庭院区域打扫问题:C++实现找出最干净区域的干净度
以下是解决该问题的C++代码: ```cpp #include <iostream> #include <vector> using namespace std; int main() { int n, q; // 输入区域数量n和打扫次数q cin >> n >> q; // 定义一个长度为n + 1的向量来存储每个区域的干净度,初始值都为0 vector<int> cleanliness(n + 1, 0); for (int i = 0; i < q; ++i) { int Li, Ri, Xi; // 输入每次打扫的范围Li到Ri以及干净度增加的值Xi cin >> Li >> Ri >> Xi; // 对从Li到Ri的区域的干净度加上Xi for (int j = Li; j <= Ri; ++j) { cleanliness[j] += Xi; } } // 初始化最大干净度为0 int maxCleanliness = 0; // 遍历所有区域,找出最大的干净度 for (int i = 1; i <= n; ++i) { if (cleanliness[i] > maxCleanliness) { maxCleanliness = cleanliness[i]; } } // 输出最干净区域的干净度 cout << maxCleanliness << endl; return 0; } ``` ### 代码解释: 1. **输入读取**:首先读取区域的数量`n`和打扫的次数`q`。 2. **初始化干净度数组**:使用`vector<int>`来存储每个区域的干净度,初始值都为0。 3. **模拟打扫过程**:通过循环`q`次,每次读取打扫的范围`Li`到`Ri`以及干净度增加的值`Xi`,并将对应区域的干净度加上`Xi`。 4. **找出最大干净度**:遍历所有区域的干净度,找出其中的最大值。 5. **输出结果**:输出最干净区域的干净度。 ######[AI问答 | 482点数解答 | 2026-02-28 20:45:52]
- Python 实现球类:精准计算半径、表面积与体积,附输入验证与异常处理!(阿里通义 | 261点数解答 | 2024-11-28 21:19:39)331
- 51 单片机:定时器 0 实现 8 个 LED 循环点亮,附代码及优化建议(字节豆包 | 1193点数解答 | 2024-12-27 15:10:29)298
- 用 Pandas 深度剖析数据:从读取到统计分析全流程实战(GPT | 642点数解答 | 2024-06-30 15:39:49)350
- 用 Pandas 深入分析招聘数据:从数据读取到可视化全流程解析(GPT | 1539点数解答 | 2024-06-30 15:56:50)357
- C++ 破解数字游戏:找出数组添加全排列后相同数字最大数量(字节豆包 | 456点数解答 | 2025-02-27 18:56:24)265
- C++助力小小李老师:求解数组添加排列后最多相同数字数量(字节豆包 | 424点数解答 | 2025-03-01 14:46:52)212
- C++助力小小李老师:破解数组数字游戏最高得分之谜(字节豆包 | 434点数解答 | 2025-03-05 07:50:34)230
- C++ 助力小小李老师玩转数字游戏,找出数组最大相同元素次数!(DeepSeek | 1118点数解答 | 2025-03-25 21:11:51)183
- C++ 助力小小李老师:解决数组添加排列找最大重复元素难题(DeepSeek | 833点数解答 | 2025-03-26 17:06:19)165
- C++助力小小李老师:破解数组排列数字游戏最高得分之谜(DeepSeek | 901点数解答 | 2025-03-26 17:08:11)170
- C++ 破解数字游戏:为数组添加排列找出最大相同元素数量(DeepSeek | 1815点数解答 | 2025-03-27 17:50:16)175
- C++ 助力小小李老师:找出数组添加排列后相同数字的最大数量 (DeepSeek | 762点数解答 | 2025-03-27 17:53:47)169