UDP广播协议叫吃饭


私信TA

用户名:Mustenaka

访问量:148572

签 名:

个人博客www.mustenaka.cn

等  级
排  名 13
经  验 25261
参赛次数 8
文章发表 197
年  龄 3
在职情况 学生
学  校 Sky_box
专  业 NE

  自我简介:

欢迎光临我的博客www.mustenaka.cn,Python,C#,U3D,C/C++开发合作可以找我

解题思路:
    Do you know Minesweeper?

    It's mean "扫雷"
    

    扫雷玩过没有?没有的话自己打开系统自带的游戏——扫雷,玩一下。

    其主要是更具一个原点判断某个点周围“地雷”(用"*"表示)的数量,这个周围就是刚好一个全共八个点,可以直接使用一个dir数组把这些方向提前存下来进行判断。   


直接上代码:

#include<bits/stdc++.h>
#define hh ios::sync_with_stdio(false),cin.tie(0),cout.tie(0)
using namespace std;
const int maxn=105;
char mp[maxn][maxn];
int dir[8][2]={-1,-1,0,-1,1,-1,-1,0,1,0,-1,1,0,1,1,1};
int n,m,pos=1;
void fmap(){
	for(int i=1;i<=n;i++){
		for(int j=1;j<=m;j++){
			if(mp[i][j]=='.'){
				mp[i][j]='0';
				for(int k=0;k<8;k++){
					if(mp[i+dir[k][0]][j+dir[k][1]]=='*'){
						mp[i][j]++;
					}
					
				}
			}
		}
	}
}
int main(){
	hh;
	while(cin>>n>>m&&n!=0&&m!=0){
		memset(mp,0,sizeof(mp));
		for(int i=1;i<=n;i++){
			for(int j=1;j<=m;j++){
				cin>>mp[i][j];
			}
		}
		fmap();
		cout<<"Field #"<<pos++<<":"<<endl;
		for(int i=1;i<=n;i++){
			for(int j=1;j<=m;j++){
				cout<<mp[i][j];
			}
			cout<<endl;
		}
		cout<<endl;
	}
	return 0;
}


 

0.0分

1 人评分

  评论区