叮咚叮咚


私信TA

用户名:13060009323

访问量:8837

签 名:

敲代码是一种工科生的艺术

等  级
排  名 4157
经  验 1687
参赛次数 0
文章发表 16
年  龄 21
在职情况 学生
学  校 四川工商学院
专  业

  自我简介:

解题思路:

注意事项:

参考代码:

#include<iostream>
#include<string.h>
using namespace std;
typedef struct dr{
	int x;
	int y;	
}Dr;
const Dr df[8]={-1,-1,0,-1,1,-1,-1,0,1,0,-1,1,0,1,1,1}; 
char mark[105][105];
char field[105][105];
char sweep(int x,int y,char f[][105]){
	int i,sum=48;
	if(f[x][y]=='*') return '*'; 
	for(i=0;i<8;i++)
	if(f[x+df[i].x][y+df[i].y]=='*')
	sum++;
	return (char)sum;
}
int main(){
	int l,w;
	int i,j,num=0;
	while(1){
		cin>>l>>w;
		if(l==0&&w==0)	break;
		memset(mark,0,sizeof(mark));
		num++;
		for(i=1;i<=l;i++)
			for(j=1;j<=w;j++)
				cin>>field[i][j];	//输入field
		for(i=1;i<=l;i++)			//扫描求值 
			for(j=1;j<=w;j++)
			mark[i][j]=sweep(i,j,field);
		cout<<"Field #"<<num<<":"<<endl;
		for(i=1;i<=l;i++){
			for(j=1;j<=w;j++)
			cout<<mark[i][j];
			cout<<endl;
		}
		cout<<endl;
	}
	return 0;
}


 

0.0分

0 人评分

看不懂代码?想转换其他语言的代码? 或者想问其他问题? 试试问问AI编程助手,随时响应你的问题:

编程语言转换

万能编程问答  

代码解释器

代码纠错

SQL生成与解释

  评论区