酷代码 AI
菜单
服务商
DeepSeek字节豆包讯飞星火
更多选项

C++代码:模拟粒子炮与集束粒子炮攻击护盾效果及优化

### 📝代码分析 这段C++代码模拟了两种不同类型的攻击对一组护盾的影响。以下是详细的解释: 1. **头文件和命名空间**: ```cpp #include <iostream> #include <vector> #include <algorithm> using namespace std; ``` 引入了输入输出流、向量容器和算法库,并使用标准命名空间。 2. **粒子炮攻击函数**: ```cpp void particleCannon(vector<int>& shields) { for (int& shield : shields) { shield = max(0, shield - 5); } } ``` 该函数接受一个整数向量`shields`的引用,对向量中的每个护盾值减去5,但确保护盾值不小于0。 3. **集束粒子炮攻击函数**: ```cpp void clusterParticleCannon(vector<int>& shields, int target) { int left = max(0, target - 2); int right = min(4, target); for (int i = left; i <= right; ++i) { shields[i] = max(0, shields[i] / 2); } } ``` 该函数接受一个整数向量`shields`的引用和一个目标位置`target`。它会对目标位置及其前后的护盾值除以2,但确保护盾值不小于0。 4. **主函数**: ```cpp int main() { vector<int> shields(5); for (int i = 0; i < 5; ++i) { cin >> shields[i]; } int n; cin >> n; for (int i = 0; i < n; ++i) { int attackType; cin >> attackType; if (attackType == 1) { particleCannon(shields); } else if (attackType == 2) { int target; cin >> target; clusterParticleCannon(shields, target - 1); } } for (int i = 0; i < 5; ++i) { cout << shields[i]; if (i < 4) { cout << " "; } } cout << endl; return 0; } ``` - 首先,创建一个包含5个元素的整数向量`shields`,并从标准输入读取初始护盾值。 - 接着,读取攻击次数`n`。 - 对于每次攻击,读取攻击类型`attackType`,如果是1则调用`particleCannon`函数,如果是2则读取目标位置并调用`clusterParticleCannon`函数。 - 输出经过所有攻击后每个护盾的剩余值。 ### 💡改进建议 - **输入验证**:可以添加对输入的验证,确保输入的攻击类型和目标位置在合理范围内。 - **代码可读性**:可以添加一些注释来提高代码的可读性。 ### 📍优化后的代码 ```cpp #include <iostream> #include <vector> #include <algorithm> using namespace std; // 粒子炮攻击函数,对所有护盾减去5,确保护盾值不小于0 void particleCannon(vector<int>& shields) { for (int& shield : shields) { shield = max(0, shield - 5); } } // 集束粒子炮攻击函数,对目标位置及其前后的护盾值除以2,确保护盾值不小于0 void clusterParticleCannon(vector<int>& shields, int target) { // 计算攻击范围的左边界 int left = max(0, target - 2); // 计算攻击范围的右边界 int right = min(4, target); for (int i = left; i <= right; ++i) { shields[i] = max(0, shields[i] / 2); } } int main() { vector<int> shields(5); cout << "请输入5个护盾的初始值:" << endl; for (int i = 0; i < 5; ++i) { cin >> shields[i]; } int n; cout << "请输入攻击次数:" << endl; cin >> n; for (int i = 0; i < n; ++i) { int attackType; cout << "请输入第 " << i + 1 << " 次攻击类型(1: 粒子炮,2: 集束粒子炮):" << endl; cin >> attackType; if (attackType == 1) { particleCannon(shields); } else if (attackType == 2) { int target; cout << "请输入集束粒子炮的目标位置(1 - 5):" << endl; cin >> target; // 目标位置转换为0 - 4的索引 clusterParticleCannon(shields, target - 1); } } cout << "经过所有攻击后,每个护盾的剩余值为:" << endl; for (int i = 0; i < 5; ++i) { cout << shields[i]; if (i < 4) { cout << " "; } } cout << endl; return 0; } ``` ######[AI问答 | 1261点数解答 | 2026-05-01 17:30:09]

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