题解
2025-07-06 15:21:15
发布于:广东
1阅读
0回复
0点赞
#include <iostream>
#include <vector>
#include <string>
using namespace std;
int main() {
int n, m;
cin >> n >> m;
vector<string> grid(n);
for (int i = 0; i < n; i++) {
cin >> grid[i];
}
// 8个方向的偏移量:上、下、左、右、左上、右上、左下、右下
int dx[] = {-1, -1, -1, 0, 0, 1, 1, 1};
int dy[] = {-1, 0, 1, -1, 1, -1, 0, 1};
for (int i = 0; i < n; i++) {
for (int j = 0; j < m; j++) {
if (grid[i][j] == '*') {
cout << '*';
} else {
int count = 0;
for (int k = 0; k < 8; k++) {
int ni = i + dx[k];
int nj = j + dy[k];
// 检查相邻格子是否在雷区范围内
if (ni >= 0 && ni < n && nj >= 0 && nj < m) {
if (grid[ni][nj] == '*') {
count++;
}
}
}
cout << char('0' + count);
}
}
cout << endl;
}
return 0;
}
这里空空如也
有帮助,赞一个