C++ 实现对数组前缀和的多次询问计算
以下是解决该问题的 C++ 代码: ```cpp #include <iostream> #include <vector> using namespace std; int main() { int n, m; // 输入 n 和 m cin >> n >> m; // 存储数组 a vector<int> a(n + 1); // 存储前缀和 vector<int> prefixSum(n + 1, 0); // 输入数组 a 的元素 for (int i = 1; i <= n; ++i) { cin >> a[i]; // 计算前缀和 prefixSum[i] = prefixSum[i - 1] + a[i]; } // 处理 m 次询问 for (int i = 0; i < m; ++i) { int k; cin >> k; // 输出 a[1] 到 a[k - 1] 的和 cout << prefixSum[k - 1] << endl; } return 0; } ``` ### 代码解释 1. **输入处理**:首先读取 `n` 和 `m`,分别表示数组的长度和询问的次数。 2. **前缀和计算**:使用 `prefixSum` 数组来存储前缀和,`prefixSum[i]` 表示 `a[1]` 到 `a[i]` 的和。 3. **询问处理**:对于每次询问,读取 `k`,然后输出 `prefixSum[k - 1]`,即 `a[1]` 到 `a[k - 1]` 的和。 ### 复杂度分析 - **时间复杂度**:计算前缀和的时间复杂度为 $O(n)$,处理每次询问的时间复杂度为 $O(1)$,因此总的时间复杂度为 $O(n + m)$。 - **空间复杂度**:使用了 `prefixSum` 数组,空间复杂度为 $O(n)$。 ######[AI问答 | 461点数解答 | 2026-05-30 19:19:47]
- Python 实现球类:精准计算半径、表面积与体积,附输入验证与异常处理!(阿里通义 | 261点数解答 | 2024-11-28 21:19:39)401
- C++实现计算最少添加数字次数以匹配两个数组元素(字节豆包 | 714点数解答 | 2026-03-08 19:44:54)41
- 51 单片机:定时器 0 实现 8 个 LED 循环点亮,附代码及优化建议(字节豆包 | 1193点数解答 | 2024-12-27 15:10:29)367
- 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
- 解决代码WA问题:修改整数溢出问题后的计算代码(字节豆包 | 749点数解答 | 2026-05-10 16:20:03)27
- 修正代码解决计算 f(l, r) 和出现的 WA 问题(字节豆包 | 806点数解答 | 2026-05-10 16:21:37)29
- JavaScript开发:为何 React 的 useState 用数组而非对象?优势揭秘!(阿里通义 | 202点数解答 | 2023-11-09 01:54:01)304
- C#工程师必知:数组、链表、哈希、队列、栈数据结构优缺点大揭秘! (百度文心 | 561点数解答 | 2023-11-09 17:56:30)283
- 补全代码:精准判断变量 a 是否为数组类型( | 115点数解答 | 2024-05-20 21:58:29)345
- Java 实现:从数组提取姓名并匹配同姓人员信息与数量(字节豆包 | 333点数解答 | 2024-09-10 11:58:36)215
- JS实现数组 ['0', '3'] 到多种格式字符串转换全攻略(百度文心 | 511点数解答 | 2024-10-15 11:05:43)199