注意事项:
见下代码
参考代码:
#include<stdio.h> int f(char a[100][100],int i,int j)//看每个'.'附近有没有'@'的函数 { int flag=0; if(a[i-1][j]=='@')flag=1; if(a[i+1][j]=='@')flag=1; if(a[i][j+1]=='@')flag=1; if(a[i][j-1]=='@')flag=1; return flag; } int main() { int n,t,i,j,m,cnt=0; char a[100][100]; scanf("%d",&n); for(i=0;i<n;i++) scanf("%s",a[i]); scanf("%d",&m); for(i=0;i<n;i++) //算出原始@的数目 { for(j=0;j<n;j++) { if(a[i][j]=='@') { cnt+=1; } } } for(t=1;t<m;t++) //去找每个点附近有没有‘@’ { for(i=0;i<n;i++) { for(j=0;j<n;j++) { if(a[i][j]=='.'&&f(a,i,j)==1) { cnt++; a[i][j]='*'; //有的话先不要改成@,这样会影响查看其它的‘.’ } } } for(i=0;i<n;i++) //等一趟循环出去之后再把之前需要改@改成@ { for(j=0;j<n;j++) { if(a[i][j]=='*') a[i][j]='@'; } } } printf("%d",cnt); return 0; }
0.0分
4 人评分