花园浇水问题:C++ 实现计算指定区间花的浇水次数之和
以下是使用 C++ 实现的代码: ```cpp #include <iostream> #include <vector> // 函数用于计算指定区间内花被浇水次数之和 int calculateWateringSum(const std::vector<int>& wateringCounts, int b, int y) { int sum = 0; // 遍历指定区间,累加每朵花的浇水次数 for (int i = b - 1; i < y; ++i) { sum += wateringCounts[i]; } return sum; } int main() { int n, q; // 输入花的数量和浇水轮数 std::cin >> n >> q; // 用于存储每朵花的浇水次数,初始化为 0 std::vector<int> wateringCounts(n, 0); for (int i = 0; i < q; ++i) { int L, R, x; // 输入每轮浇水的区间和浇水次数 std::cin >> L >> R >> x; // 更新指定区间内每朵花的浇水次数 for (int j = L - 1; j < R; ++j) { wateringCounts[j] += x; } } int b, y; // 输入最后询问的区间 std::cin >> b >> y; // 计算并输出指定区间内花被浇水次数之和 std::cout << calculateWateringSum(wateringCounts, b, y) << std::endl; return 0; } ``` ### 代码说明: 1. **输入处理**:首先读取花的数量 `n` 和浇水轮数 `q`。然后使用 `std::vector<int> wateringCounts(n, 0)` 创建一个长度为 `n` 的向量,初始值都为 0,用于存储每朵花的浇水次数。 2. **浇水操作**:通过循环 `q` 次,每次读取浇水的区间 `L` 到 `R` 以及浇水的次数 `x`,并更新 `wateringCounts` 向量中对应区间的元素值。 3. **询问处理**:读取最后询问的区间 `b` 到 `y`,调用 `calculateWateringSum` 函数计算该区间内花被浇水次数之和,并输出结果。 ######[AI问答 | 552点数解答 | 2026-04-19 21:56:40]
- Python实现:随机录入45位学生四次成绩函数大揭秘(GPT | 477点数解答 | 2024-12-17 17:00:35)363
- Python实现班级45位同学成绩生成、总评计算及分数统计(字节豆包 | 579点数解答 | 2024-12-21 11:55:01)252
- Python实现45位学生四次成绩随机录入及输出(GPT | 441点数解答 | 2024-12-21 21:02:22)260
- Python实战:45位同学成绩生成、总评计算与分数统计揭秘(字节豆包 | 688点数解答 | 2024-12-22 10:14:17)248
- Python 实现球类:精准计算半径、表面积与体积,附输入验证与异常处理!(阿里通义 | 261点数解答 | 2024-11-28 21:19:39)362
- 51 单片机:定时器 0 实现 8 个 LED 循环点亮,附代码及优化建议(字节豆包 | 1193点数解答 | 2024-12-27 15:10:29)333
- C++ 代码实现自定义运算 x@y = x² + y² - xy 及 x@(x+y) 计算(DeepSeek | 215点数解答 | 2025-12-13 15:08:14)87
- C++ 实现根据输入正整数奇偶性计算偶数和或约数和(字节豆包 | 838点数解答 | 2026-02-28 20:23:59)44
- C++实现:输入整数英文单词算乘积,输出数字与英文结果,可多次计算!(GPT | 2268点数解答 | 2024-05-24 01:55:27)394
- C语言巧解:计算整数区间内最遥远素数差值(阿里通义 | 428点数解答 | 2024-11-22 14:53:33)185
- C++ 实现:根据给定序列与条件计算满足要求的整数对数量(字节豆包 | 232点数解答 | 2025-04-23 17:33:20)172
- C++ 求解满足特定条件整数对数量:从 O(M^2) 到 O(N + M) 的优化(百度文心 | 1197点数解答 | 2025-04-23 17:36:27)242