C++ 实现计算连续 k 个人的最大危险程度总和
以下是使用 C++ 实现的代码: ```cpp #include <iostream> #include <vector> using namespace std; int main() { int n, k; // 读取 n 和 k cin >> n >> k; vector<int> a(n); // 读取每个守卫的危险程度 for (int i = 0; i < n; i++) { cin >> a[i]; } // 计算前 k 个人的危险程度总和 int currentSum = 0; for (int i = 0; i < k; i++) { currentSum += a[i]; } int maxSum = currentSum; // 滑动窗口计算连续 k 个人的最大危险程度总和 for (int i = k; i < n; i++) { // 减去窗口最左边的值,加上窗口最右边的值 currentSum = currentSum - a[i - k] + a[i]; // 更新最大危险程度总和 if (currentSum > maxSum) { maxSum = currentSum; } } // 输出结果 cout << maxSum << endl; return 0; } ``` ### 代码解释: 1. **输入处理**:首先读取 `n` 和 `k`,分别表示守卫的数量和要麻醉的连续人数。然后读取每个守卫的危险程度并存储在数组 `a` 中。 2. **初始化**:计算前 `k` 个人的危险程度总和 `currentSum`,并将其赋值给 `maxSum`。 3. **滑动窗口**:从第 `k` 个人开始,使用滑动窗口的方法,每次减去窗口最左边的值,加上窗口最右边的值,更新 `currentSum`。比较 `currentSum` 和 `maxSum` 的大小,如果 `currentSum` 更大,则更新 `maxSum`。 4. **输出结果**:最后输出 `maxSum`,即危险程度最高的 `k` 个人的危险程度总和。 ######[AI问答 | 488点数解答 | 2026-05-30 16:07:07]
- 麻醉炮弹问题的C++滑动窗口解法(字节豆包 | 672点数解答 | 2026-04-04 19:50:57)23
- 用C++计算连续k个守卫的最大危险程度总和(字节豆包 | 242点数解答 | 2026-04-08 21:12:35)45
- C++ 滑动窗口求解连续子数组最大和问题(DeepSeek | 929点数解答 | 2026-05-22 19:55:51)10
- 计算连续 k 个人最大危险程度总和的 C++ 代码实现(字节豆包 | 479点数解答 | 2026-05-24 14:10:53)11
- Python滑动窗口算法解决连续守卫最大危险程度总和问题(字节豆包 | 695点数解答 | 2026-05-29 20:49:48)6
- C++实现麻醉炮弹最大危险程度总和计算及开发建议(字节豆包 | 811点数解答 | 2026-05-29 20:50:16)6
- C++ 实现计算连续 k 个人的最大危险程度总和(字节豆包 | 488点数解答 | 2026-05-30 16:07:07)3
- 麻醉炮弹问题:计算连续k人最高危险程度总和(字节豆包 | 134点数解答 | 2026-05-30 19:31:03)2
- 使用C++计算麻醉炮弹麻醉连续k个人的最大危险程度总和(字节豆包 | 308点数解答 | 2026-05-30 19:37:31)2
- Python 实现球类:精准计算半径、表面积与体积,附输入验证与异常处理!(阿里通义 | 261点数解答 | 2024-11-28 21:19:39)401
- 深入解析洛谷打卡系统:规则揭秘与代码实现(字节豆包 | 316点数解答 | 2025-11-16 19:45:59)143
- 高考毕业晚会难题:从学生能力值求最大默契程度的Python解法(字节豆包 | 487点数解答 | 2026-01-24 13:10:18)67