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]
- 网络安全必知:CSRF 攻击揭秘与七大防御妙招! (百度文心 | 239点数解答 | 2023-11-09 18:35:43)248
- 网络安全工程师揭秘:DOS、DDoS、DRDoS攻击原理与防范策略(百度文心 | 327点数解答 | 2023-11-09 18:35:59)238
- 解析React 15与Vue 2:从O(n^3)到O(n),Diff算法时间复杂度计算及性能对比 (阿里通义 | 379点数解答 | 2023-11-09 01:49:19)350
- 缜密逻辑,全新无名杀“风餐”技能代码精心打造与深度解析 (字节豆包 | 469点数解答 | 2025-04-05 11:37:06)266
- 精准优化:明确需求,开启高效提升之旅! (字节豆包 | 52点数解答 | 2026-02-09 16:44:46)56
- 代码再升级:优化版“获取dump”代码,多机制保障数据读取与保存(字节豆包 | 734点数解答 | 2026-02-10 01:23:31)81
- 代码深度优化:全面检查异常、灵活读取内存,提升可读性与可维护性(字节豆包 | 959点数解答 | 2026-02-10 01:24:14)54
- 洛谷乒乓球题解:11 分制与 21 分制比赛结果计算全攻略(DeepSeek | 675点数解答 | 2025-04-28 18:19:45)318
- C++ 模拟:助冒险者用神秘数字构建直角三角形,开发要点大揭秘! (DeepSeek | 156点数解答 | 2025-09-14 21:30:10)315
- P1007:小核桃数组变换难题,Python代码揭秘最终平方和!(字节豆包 | 416点数解答 | 2026-02-07 18:24:18)63
- P1007小核桃数组变换难题:C++代码求解最终两数平方和! (字节豆包 | 651点数解答 | 2026-02-07 18:25:02)64
- “天气之子”试炼:用代码破解天气预报成功天数之谜,复杂度分析揭秘!(字节豆包 | 797点数解答 | 2026-02-07 18:29:12)50