酷代码 AI
菜单
服务商

C++实现矩阵指定位置周边元素修改

### 🌌思路分析 要解决这个问题,我们需要对矩阵中指定位置 `(x, y)` 的左上方、上方和右上方元素进行检查,如果这些位置存在于矩阵范围内,就将其设置为字符 `'0'`。 ### 📦代码实现 ```cpp #include <iostream> #include <vector> using namespace std; int main() { int n, m; // 输入矩阵的行数和列数 cin >> n >> m; // 定义字符矩阵 vector<vector<char>> matrix(n, vector<char>(m)); // 输入矩阵元素 for (int i = 0; i < n; ++i) { for (int j = 0; j < m; ++j) { cin >> matrix[i][j]; } } int x, y; // 输入指定位置 cin >> x >> y; // 检查并修改左上方元素 if (x > 0 && y > 0) { matrix[x - 1][y - 1] = '0'; } // 检查并修改上方元素 if (x > 0) { matrix[x - 1][y] = '0'; } // 检查并修改右上方元素 if (x > 0 && y < m - 1) { matrix[x - 1][y + 1] = '0'; } // 输出修改后的矩阵 for (int i = 0; i < n; ++i) { for (int j = 0; j < m; ++j) { cout << matrix[i][j]; } cout << endl; } return 0; } ``` ### 📋代码解释 1. **输入矩阵**:首先读取矩阵的行数 `n` 和列数 `m`,然后使用二维向量 `matrix` 存储矩阵元素。 2. **输入指定位置**:读取指定位置 `(x, y)`。 3. **修改元素**:分别检查左上方、上方和右上方元素是否存在,如果存在则将其设置为字符 `'0'`。 4. **输出矩阵**:遍历矩阵并输出修改后的矩阵。 ### ⚙️复杂度分析 - **时间复杂度**:$O(n * m)$,主要用于输入和输出矩阵。 - **空间复杂度**:$O(n * m)$,用于存储矩阵。 ### 💡开发建议 - **边界检查**:在修改元素时,一定要进行边界检查,避免越界访问。 - **代码可读性**:可以将修改元素的逻辑封装成函数,提高代码的可读性和可维护性。 ######[AI写代码神器 | 641点数解答 | 2026-04-10 19:37:00]

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