酷代码 AI
菜单
服务商

C++实现防御矩阵武器布局及开发建议

### 🔍思路分析 本题的目标是创建一个 `n×n` 的矩阵,将编号从 1 到 `n` 的武器依次放置在矩阵的主对角线上,其余位置填充为 0。我们可以通过两层循环来遍历矩阵,当行索引和列索引相等时,将对应位置赋值为当前武器编号。 ### 💻代码实现 ```cpp #include <iostream> using namespace std; const int MAXN = 5; int main() { int n; int a[MAXN][MAXN]; // 输入矩阵的大小 cin >> n; // 初始化矩阵 for (int i = 0; i < n; i++) { for (int j = 0; j < n; j++) { if (i == j) { // 主对角线上的元素赋值为武器编号 a[i][j] = i + 1; } else { // 非主对角线上的元素赋值为 0 a[i][j] = 0; } } } // 输出矩阵 for (int i = 0; i < n; i++) { for (int j = 0; j < n; j++) { cout << a[i][j]; if (j < n - 1) { cout << " "; } } cout << endl; } return 0; } ``` ### 📝代码解释 1. **头文件和命名空间**:包含必要的头文件 `<iostream>`,并使用 `using namespace std;` 简化代码。 2. **输入矩阵大小**:使用 `cin` 读取用户输入的矩阵大小 `n`。 3. **初始化矩阵**:通过两层循环遍历矩阵,当 `i == j` 时,将 `a[i][j]` 赋值为 `i + 1`,表示放置武器编号;否则,将其赋值为 0。 4. **输出矩阵**:再次使用两层循环遍历矩阵,将每个元素输出,元素之间用空格分隔,每行结束后换行。 ### ⚙️复杂度分析 - **时间复杂度**:$O(n^2)$,其中 `n` 是矩阵的大小。需要遍历矩阵的每个元素一次。 - **空间复杂度**:$O(n^2)$,主要用于存储矩阵。 ### 🚀开发建议 - **边界检查**:可以在读取输入时添加对 `n` 的边界检查,确保 `n` 在 1 到 5 之间。 - **错误处理**:可以添加对输入的错误处理,例如输入不是整数的情况。 - **代码复用**:将矩阵的初始化和输出封装成函数,提高代码的复用性。 ######[AI写代码神器 | 655点数解答 | 2026-03-14 20:31:37]

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