快速计算队员战斗力区间和的 C++ 实现
```cpp #include <iostream> using namespace std; int main() { int n, m; cin >> n >> m; int a[100001]; int prefixSum[100001] = {0}; for (int i = 1; i <= n; ++i) { cin >> a[i]; prefixSum[i] = prefixSum[i - 1] + a[i]; } for (int i = 0; i < m; ++i) { int L, R; cin >> L >> R; cout << prefixSum[R] - prefixSum[L - 1] << endl; } return 0; } ``` ### 代码解释 1. **输入部分**:先读取队员数量 `n` 和考验次数 `m`。接着读取每个队员的战斗力 `a[i]`,同时计算前缀和数组 `prefixSum`,`prefixSum[i]` 表示前 `i` 个队员的战斗力总和。 2. **询问处理**:对于每次考验,读取区间 `[L, R]`,通过 `prefixSum[R] - prefixSum[L - 1]` 计算出该区间内队员的战斗力之和并输出。 ### 复杂度分析 - **时间复杂度**:计算前缀和的时间复杂度是 $O(n)$,每次询问的时间复杂度是 $O(1)$,所以总的时间复杂度为 $O(n + m)$。 - **空间复杂度**:使用了前缀和数组,空间复杂度为 $O(n)$。 ######[AI问答 | 382点数解答 | 2026-05-30 19:24:50]
- Python实现:随机录入45位学生四次成绩函数大揭秘(GPT | 477点数解答 | 2024-12-17 17:00:35)382
- Python实现班级45位同学成绩生成、总评计算及分数统计(字节豆包 | 579点数解答 | 2024-12-21 11:55:01)271
- Python实现45位学生四次成绩随机录入及输出(GPT | 441点数解答 | 2024-12-21 21:02:22)276
- Python实战:45位同学成绩生成、总评计算与分数统计揭秘(字节豆包 | 688点数解答 | 2024-12-22 10:14:17)263
- Python 实现球类:精准计算半径、表面积与体积,附输入验证与异常处理!(阿里通义 | 261点数解答 | 2024-11-28 21:19:39)401
- 51 单片机:定时器 0 实现 8 个 LED 循环点亮,附代码及优化建议(字节豆包 | 1193点数解答 | 2024-12-27 15:10:29)367
- C++实现:输入整数英文单词算乘积,输出数字与英文结果,可多次计算!(GPT | 2268点数解答 | 2024-05-24 01:55:27)406
- C语言巧解:计算整数区间内最遥远素数差值(阿里通义 | 428点数解答 | 2024-11-22 14:53:33)194
- C++ 实现:根据给定序列与条件计算满足要求的整数对数量(字节豆包 | 232点数解答 | 2025-04-23 17:33:20)179
- C++ 求解满足特定条件整数对数量:从 O(M^2) 到 O(N + M) 的优化(百度文心 | 1197点数解答 | 2025-04-23 17:36:27)254
- C++ 代码实现自定义运算 x@y = x² + y² - xy 及 x@(x+y) 计算(DeepSeek | 215点数解答 | 2025-12-13 15:08:14)111
- C++ 实现根据输入正整数奇偶性计算偶数和或约数和(字节豆包 | 838点数解答 | 2026-02-28 20:23:59)79