计算连续 k 个人最大危险程度总和的 C++ 代码实现
以下是解决该问题的代码: ```cpp #include <iostream> #include <algorithm> using namespace std; const int MAXN = 100005; int a[MAXN]; int main() { int n, k; // 输入 n 和 k cin >> n >> k; // 输入每个守卫的危险程度 for (int i = 1; i <= n; i++) { cin >> a[i]; } // 计算前 k 个人的危险程度总和 int sum = 0; for (int i = 1; i <= k; i++) { sum += a[i]; } // 初始化最大危险程度总和为前 k 个人的危险程度总和 int ans = sum; // 从第 k+1 个人开始,依次计算连续 k 个人的危险程度总和 for (int i = k + 1; i <= n; i++) { // 减去最前面那个人的危险程度,加上当前这个人的危险程度 sum = sum - a[i - k] + a[i]; // 更新最大危险程度总和 ans = max(ans, sum); } // 输出最大危险程度总和 cout << ans; return 0; } ``` ### 代码解释 1. **输入处理**:首先读取 `n` 和 `k`,然后读取每个守卫的危险程度并存储在数组 `a` 中。 2. **计算初始和**:计算前 `k` 个人的危险程度总和 `sum`,并将其作为初始的最大危险程度总和 `ans`。 3. **滑动窗口**:从第 `k+1` 个人开始,使用滑动窗口的思想,每次减去窗口最前面那个人的危险程度,加上当前这个人的危险程度,更新 `sum`,并更新最大危险程度总和 `ans`。 4. **输出结果**:输出最大危险程度总和 `ans`。 ######[AI问答 | 479点数解答 | 2026-05-24 14:10:53]
- 麻醉炮弹问题的C++滑动窗口解法(字节豆包 | 672点数解答 | 2026-04-04 19:50:57)21
- 用C++计算连续k个守卫的最大危险程度总和(字节豆包 | 242点数解答 | 2026-04-08 21:12:35)41
- C++ 滑动窗口求解连续子数组最大和问题(DeepSeek | 929点数解答 | 2026-05-22 19:55:51)6
- 计算连续 k 个人最大危险程度总和的 C++ 代码实现(字节豆包 | 479点数解答 | 2026-05-24 14:10:53)5
- Python 实现球类:精准计算半径、表面积与体积,附输入验证与异常处理!(阿里通义 | 261点数解答 | 2024-11-28 21:19:39)397
- 深入解析洛谷打卡系统:规则揭秘与代码实现(字节豆包 | 316点数解答 | 2025-11-16 19:45:59)141
- 高考毕业晚会难题:从学生能力值求最大默契程度的Python解法(字节豆包 | 487点数解答 | 2026-01-24 13:10:18)65
- 51 单片机:定时器 0 实现 8 个 LED 循环点亮,附代码及优化建议(字节豆包 | 1193点数解答 | 2024-12-27 15:10:29)364
- 用 JS 中 for 循环实现 1 到 100 相加并输出结果到页面的完整代码 ( | 240点数解答 | 2024-05-20 22:11:29)515
- 用 JS 的 while 循环实现 1 到 100 相加并输出到页面的代码揭秘( | 47点数解答 | 2024-05-20 22:16:48)397
- C++ 代码实现自定义运算 x@y = x² + y² - xy 及 x@(x+y) 计算(DeepSeek | 215点数解答 | 2025-12-13 15:08:14)108
- C++ 实现根据输入正整数奇偶性计算偶数和或约数和(字节豆包 | 838点数解答 | 2026-02-28 20:23:59)72