全RE求助
查看原帖
全RE求助
1200191
封禁用户楼主2024/10/2 11:12
#include <bits/stdc++.h>
#define ll long long
using namespace std;
int n,m;
char a[101][101];
int b[101][101]={0};
int fx[8] = {1,0,-1,0,-1,1,1,-1};
int fy[8] = {0,1,0,-1,-1,-1,1,1};
int dfs(int x,int y) {
	int nx,ny,k;
	for (k=0; k<8; k++) {
		nx=x+fx[k];
		ny=y+fy[k];
		if (nx>=1&&nx<=n&&ny>=1&&ny<=m){
			b[nx][ny]++;
		}
	}
}
int main() {
	//freopen("扫雷游戏.in", "r", stdin);
	//freopen("扫雷游戏.out", "w", stdout);
	cin>>n>>m;
	for(int i=1; i<=n; i++) {
		for(int j=1; j<=m; j++) {
			cin>>a[i][j];
			if(a[i][j]=='*') {
				dfs(i,j);
			}
		}
	}
	for(int i=1;i<=n;i++){
		for(int j=1;j<=m;j++){
			if(a[i][j]=='*')cout<<'*';
			else cout<<b[i][j];
		}
		cout<<"\n";
	}
	return 0;
}

2024/10/2 11:12
加载中...