花园浇水问题:差分数组与前缀和高效解法
```cpp #include <iostream> #include <vector> using namespace std; int main() { int n, q; cin >> n >> q; vector<int> flowers(n + 1, 0); vector<long long> prefixSum(n + 1, 0); for (int i = 0; i < q; i++) { int L, R, x; cin >> L >> R >> x; flowers[L] += x; if (R + 1 <= n) { flowers[R + 1] -= x; } } for (int i = 1; i <= n; i++) { flowers[i] += flowers[i - 1]; } for (int i = 1; i <= n; i++) { prefixSum[i] = prefixSum[i - 1] + flowers[i]; } int queryL, queryR; cin >> queryL >> queryR; long long result = prefixSum[queryR] - prefixSum[queryL - 1]; cout << result << endl; return 0; } ``` 🌺 **算法解析** - 使用差分数组记录浇水操作,将区间更新转化为两个单点更新。 - 通过前缀和恢复每朵花的最终浇水次数。 - 利用前缀和数组快速计算任意区间浇水次数总和。 ⚙️ **复杂度分析** - 时间复杂度:O(n + q),高效处理大规模数据。 - 空间复杂度:O(n),仅需两个辅助数组。 💡 **使用示例** 输入: ``` 5 3 1 3 2 2 4 1 3 5 3 2 4 ``` 输出: ``` 16 ``` 解释: - 最终每朵花浇水次数:[2, 3, 6, 4, 3] - 区间[2,4]总和:3 + 6 + 4 = 13 ######[AI问答 | 434点数解答 | 2026-03-20 22:00:04]
- 巴黎奥运:中国女排淘汰赛对决土耳其,朱婷成致胜关键!(字节豆包 | 448点数解答 | 2024-08-06 15:59:48)162
- C++实现计算最少添加数字次数以匹配两个数组元素(字节豆包 | 714点数解答 | 2026-03-08 19:44:54)13
- 浙闽“板凳龙”舞龙队 300 秒螺线盘入:位置与速度全揭秘(阿里通义 | 886点数解答 | 2024-09-07 10:31:31)628
- 浙闽“板凳龙”舞龙队 300 秒位置与速度数学模型揭秘(GPT | 565点数解答 | 2024-09-07 10:32:56)526
- 223节板凳龙沿等距螺线盘入:300秒内位置与速度的数学揭秘 (讯飞星火 | 443点数解答 | 2024-09-07 10:34:10)372
- 浙闽“板凳龙”300秒舞龙轨迹与速度:数学模型揭秘!(字节豆包 | 522点数解答 | 2024-09-07 10:35:06)344
- Excel 销售数据难题:2024 年 Q3 及特定时段销售情况计算全攻略(字节豆包 | 762点数解答 | 2024-11-06 19:11:51)187
- 从封闭到觉醒:中国在西方文化冲击下的曲折蜕变(讯飞星火 | 331点数解答 | 2024-11-30 21:50:57)188
- 陈独秀〈吾人最后之觉悟〉:文化冲突下的觉醒与奋进之路(百度文心 | 458点数解答 | 2024-11-30 21:51:52)197
- 从文化冲突到国民觉悟:中国近代变革的觉醒之路( | 21点数解答 | 2024-11-30 21:52:33)191
- Python:生成含随机缺失值二维数组并处理,附随机选元素赋缺失值代码解析(阿里通义 | 300点数解答 | 2025-03-13 20:19:30)215
- 破解“没有3的世界”:找出第n个合规正整数!(DeepSeek | 471点数解答 | 2025-03-17 14:32:58)248