酷代码 AI
菜单
服务商

C++ 实现小核桃攻击敌人护盾能量计算

以下是实现该功能的 C++ 代码: ```cpp #include <iostream> #include <vector> // 粒子炮攻击函数 void particleCannon(std::vector<int>& shields) { for (int i = 0; i < shields.size(); ++i) { shields[i] = std::max(0, shields[i] - 5); } } // 集束粒子炮攻击函数 void clusterParticleCannon(std::vector<int>& shields, int target) { // 调整目标索引为从 0 开始 target--; // 处理目标敌人 shields[target] = std::max(0, shields[target] / 2); // 处理目标敌人左边的敌人 if (target > 0) { shields[target - 1] = std::max(0, shields[target - 1] / 2); } // 处理目标敌人右边的敌人 if (target < shields.size() - 1) { shields[target + 1] = std::max(0, shields[target + 1] / 2); } } int main() { std::vector<int> shields(5); // 输入 5 名敌人的护盾能量值 for (int i = 0; i < 5; ++i) { std::cin >> shields[i]; } int n; // 输入攻击次数 std::cin >> n; for (int i = 0; i < n; ++i) { int attackType; std::cin >> attackType; if (attackType == 1) { // 粒子炮攻击 particleCannon(shields); } else if (attackType == 2) { int target; std::cin >> target; // 集束粒子炮攻击 clusterParticleCannon(shields, target); } } // 输出攻击后的护盾能量值 for (int i = 0; i < 5; ++i) { std::cout << shields[i]; if (i < 4) { std::cout << " "; } } std::cout << std::endl; return 0; } ``` ### 代码解释: 1. **`particleCannon` 函数**:该函数用于实现粒子炮攻击,遍历所有敌人的护盾能量值,将每个护盾能量值减去 5,并确保结果不小于 0。 2. **`clusterParticleCannon` 函数**:该函数用于实现集束粒子炮攻击,根据输入的目标敌人编号,将目标敌人及其相邻的敌人的护盾能量值除以 2,并确保结果不小于 0。 3. **`main` 函数**:首先读取 5 名敌人的护盾能量值,然后读取攻击次数。接着,根据攻击类型调用相应的攻击函数。输出攻击后的护盾能量值。 ### 复杂度分析: - **时间复杂度**:$O(n)$,其中 $n$ 是攻击次数。 - **空间复杂度**:$O(1)$,只使用了常数级的额外空间。 ######[AI问答 | 757点数解答 | 2026-03-28 15:59:23]

相关提问
本站限时免费提问中
实用工具查看更多
Linux在线手册 [开发类]
Jquery在线手册 [开发类]
今日油价 [生活类]
图片互转base64 [开发类]
时间转换器 [开发类]