FZU 1056 扫雷游戏
2015-10-31 14:59
483 查看
题目链接:http://acm.fzu.edu.cn/problem.php?pid=1056
#include<cstdio>
#include<cstring>
#include<iostream>
#include<algorithm>
#include<vector>
using namespace std;
int main()
{
int n,m;
char a[105][105],s[105][105];
while(~scanf("%d%d",&n,&m))
{
if(n==0&&m==0)
break;
else
{
memset(s,'0',sizeof(s));
memset(a,'0',sizeof(a));
int i,j;
for(i=1; i<=n; i++)
for(j=1; j<=m; j++)
cin>>a[i][j];//用scanf不行,cin就过了
for(i=1; i<=n; i++)
for(j=1; j<=m; j++)
{
if(a[i][j]=='*')
s[i][j]='*';
else
{
for(int k=-1; k<=1; k++)
for(int l=-1; l<=1; l++)
if(a[i+k][j+l]=='*'&&((i+k)!=i||(j+l)!=j))
s[i][j]+=1;
}
}
for(i=1; i<=n; i++)
{
for(j=1; j<=m; j++)
{
printf("%c",s[i][j]);
}
printf("\n");
}
printf("\n");
}
}
return 0;
}
#include<cstdio>
#include<cstring>
#include<iostream>
#include<algorithm>
#include<vector>
using namespace std;
int main()
{
int n,m;
char a[105][105],s[105][105];
while(~scanf("%d%d",&n,&m))
{
if(n==0&&m==0)
break;
else
{
memset(s,'0',sizeof(s));
memset(a,'0',sizeof(a));
int i,j;
for(i=1; i<=n; i++)
for(j=1; j<=m; j++)
cin>>a[i][j];//用scanf不行,cin就过了
for(i=1; i<=n; i++)
for(j=1; j<=m; j++)
{
if(a[i][j]=='*')
s[i][j]='*';
else
{
for(int k=-1; k<=1; k++)
for(int l=-1; l<=1; l++)
if(a[i+k][j+l]=='*'&&((i+k)!=i||(j+l)!=j))
s[i][j]+=1;
}
}
for(i=1; i<=n; i++)
{
for(j=1; j<=m; j++)
{
printf("%c",s[i][j]);
}
printf("\n");
}
printf("\n");
}
}
return 0;
}
相关文章推荐
- FZU 2148: Moon Game 四边形的月亮
- FZU - 2148 Moon Game
- FZU 2037
- FZU - 2110 Star
- FZU 2102 Solve equation
- FZU 2104 C - Floor problem
- FZU 2111 Min Number
- FZU Problem 2054 拳王
- FZU 1759 Super A^B mod C (快速幂+指数循环节)
- FZU 1752 A^B mod C (快速幂)
- FZU 2203 单纵大法好 (二分+贪心)
- HDU 2108 字符串递归
- FZU 2082 树链剖分 区间最大和
- FZU - 2115 多项式积分
- Fzu 2036 Log Calculator(JAVA 浮点数输出精度控制)
- acm fzu 2108 Mod problem
- fzu 2120 数字排列
- FZU 2150 Fire Game
- FZU 2150 Fire Game 多起点BFS
- FZU 2196 Escape BFS