密室攻防大战:计算护盾最少移动次数的 C++ 实现
以下是解决该问题的 C++ 代码: ```cpp #include <iostream> #include <vector> // 计算护盾最少移动次数的函数 int minShieldMoves(int n, int L, int R, std::vector<int> attacks) { int moves = 0; // 遍历每一次攻击 for (int attack : attacks) { // 如果攻击位置在护盾左边 if (attack < L) { // 计算需要向左移动的距离 int moveLeft = L - attack; moves += moveLeft; // 更新护盾的左右端点 L -= moveLeft; R -= moveLeft; } // 如果攻击位置在护盾右边 else if (attack > R) { // 计算需要向右移动的距离 int moveRight = attack - R; moves += moveRight; // 更新护盾的左右端点 L += moveRight; R += moveRight; } } return moves; } int main() { int n, L, R; // 读取密室列数、护盾初始左右端点 std::cin >> n >> L >> R; int m; // 读取攻击次数 std::cin >> m; std::vector<int> attacks(m); // 读取每次攻击的列数 for (int i = 0; i < m; ++i) { std::cin >> attacks[i]; } // 调用函数计算最少移动次数 int result = minShieldMoves(n, L, R, attacks); // 输出结果 std::cout << result << std::endl; return 0; } ``` ### 代码解释: 1. **`minShieldMoves` 函数**: - 该函数接收密室列数 `n`、护盾初始左右端点 `L` 和 `R` 以及攻击列数的向量 `attacks` 作为参数。 - 遍历每一次攻击,根据攻击位置与护盾位置的关系进行处理: - 如果攻击位置在护盾左边,计算需要向左移动的距离并更新护盾的左右端点。 - 如果攻击位置在护盾右边,计算需要向右移动的距离并更新护盾的左右端点。 - 最后返回护盾移动的总次数。 2. **`main` 函数**: - 读取输入的密室列数、护盾初始左右端点、攻击次数和每次攻击的列数。 - 调用 `minShieldMoves` 函数计算最少移动次数。 - 输出结果。 ### 复杂度分析: - **时间复杂度**:$O(m)$,其中 $m$ 是攻击的次数。因为只需要遍历一次攻击列表。 - **空间复杂度**:$O(m)$,主要用于存储攻击列数的向量。 ######[AI问答 | 679点数解答 | 2026-03-14 19:46:56]
- Python 实现球类:精准计算半径、表面积与体积,附输入验证与异常处理!(阿里通义 | 261点数解答 | 2024-11-28 21:19:39)339
- 8 - 1 数据结构大作业:功能完备、跨平台的资源管理器设计与实现 (GPT | 654点数解答 | 2024-12-04 19:07:22)350
- 数据结构大作业:100分资源管理器设计与实现,功能全、评分明!(GPT | 186点数解答 | 2024-12-04 21:33:38)236
- Python实现资源管理器大作业:涵盖多操作功能与错误处理要点(字节豆包 | 883点数解答 | 2024-12-05 15:03:36)243
- Python 实现资源管理器:管理、预览、操作文件与文件夹,附代码及注意要点(字节豆包 | 427点数解答 | 2024-12-05 15:06:07)360
- C 语言实现多功能资源管理器:含文件管理、预览及操作功能(字节豆包 | 607点数解答 | 2024-12-05 15:06:26)289
- 小学1年级“资源管理器”知识测试卷大揭秘!(字节豆包 | 374点数解答 | 2024-12-19 17:01:35)225
- 大三资源管理器测试卷:从理论到编程实战全解析(阿里通义 | 2000点数解答 | 2024-12-19 17:03:30)188
- Python 实现资源管理器:含代码示例与功能拓展要点,数据结构大作业示范 (字节豆包 | 526点数解答 | 2024-12-31 16:31:21)181
- Java 实现功能丰富的资源管理器:含代码示例与注意要点,数据结构大作业来袭! (字节豆包 | 499点数解答 | 2024-12-31 16:31:32)180
- C语言打造超实用资源管理器:文件管理、预览与操作全实现!(DeepSeek | 1797点数解答 | 2025-07-11 01:46:58)110
- 51 单片机:定时器 0 实现 8 个 LED 循环点亮,附代码及优化建议(字节豆包 | 1193点数解答 | 2024-12-27 15:10:29)308