C++ 实现花园花朵浇水次数统计及区间求和
以下是使用 C++ 解决该问题的代码: ```cpp #include <iostream> #include <vector> using namespace std; int main() { int n, q; // 输入花的数量 n 和浇水轮数 q cin >> n >> q; // 初始化每朵花的浇水次数为 0 vector<int> waterCount(n + 1, 0); // 进行 q 轮浇水 for (int i = 0; i < q; ++i) { int L, R, x; // 输入每轮浇水的区间 [L, R] 和浇水次数 x cin >> L >> R >> x; // 对区间 [L, R] 内的花增加浇水次数 for (int j = L; j <= R; ++j) { waterCount[j] += x; } } int left, right; // 输入要查询的区间 [left, right] cin >> left >> right; int sum = 0; // 计算区间 [left, right] 内每朵花浇水次数之和 for (int i = left; i <= right; ++i) { sum += waterCount[i]; } // 输出结果 cout << sum << endl; return 0; } ``` ### 代码解释: 1. **输入处理**:首先读取花的数量 `n` 和浇水轮数 `q`。然后使用 `vector` 存储每朵花的浇水次数,初始值都为 0。 2. **浇水操作**:进行 `q` 轮浇水,每轮输入浇水的区间 `[L, R]` 和浇水次数 `x`,将该区间内的每朵花的浇水次数增加 `x`。 3. **查询操作**:输入要查询的区间 `[left, right]`,计算该区间内每朵花浇水次数之和。 4. **输出结果**:输出查询区间内每朵花浇水次数之和。 ### 复杂度分析: - **时间复杂度**:浇水操作的时间复杂度为 $O(q * (R - L + 1))$,查询操作的时间复杂度为 $O(right - left + 1)$。 - **空间复杂度**:$O(n)$,主要用于存储每朵花的浇水次数。 ######[AI问答 | 560点数解答 | 2026-04-17 20:20:58]
- Python实现:随机录入45位学生四次成绩函数大揭秘(GPT | 477点数解答 | 2024-12-17 17:00:35)360
- Python实现班级45位同学成绩生成、总评计算及分数统计(字节豆包 | 579点数解答 | 2024-12-21 11:55:01)248
- Python实现45位学生四次成绩随机录入及输出(GPT | 441点数解答 | 2024-12-21 21:02:22)258
- Python实战:45位同学成绩生成、总评计算与分数统计揭秘(字节豆包 | 688点数解答 | 2024-12-22 10:14:17)247
- Python 实现球类:精准计算半径、表面积与体积,附输入验证与异常处理!(阿里通义 | 261点数解答 | 2024-11-28 21:19:39)361
- 51 单片机:定时器 0 实现 8 个 LED 循环点亮,附代码及优化建议(字节豆包 | 1193点数解答 | 2024-12-27 15:10:29)331
- C++实现:输入整数英文单词算乘积,输出数字与英文结果,可多次计算!(GPT | 2268点数解答 | 2024-05-24 01:55:27)394
- C语言巧解:计算整数区间内最遥远素数差值(阿里通义 | 428点数解答 | 2024-11-22 14:53:33)184
- C++ 实现:根据给定序列与条件计算满足要求的整数对数量(字节豆包 | 232点数解答 | 2025-04-23 17:33:20)171
- C++ 求解满足特定条件整数对数量:从 O(M^2) 到 O(N + M) 的优化(百度文心 | 1197点数解答 | 2025-04-23 17:36:27)240
- 用 Pandas 深度剖析数据:从读取到统计分析全流程实战(GPT | 642点数解答 | 2024-06-30 15:39:49)368
- 用 Pandas 深入分析招聘数据:从数据读取到可视化全流程解析(GPT | 1539点数解答 | 2024-06-30 15:56:50)380