解题思路:
注意事项:
参考代码:
#include <iostream>
using namespace std;
int main()
{
int M,N,i,j,m,k,num=0;
while(cin >>M>>N&&M&&N){
num++;
char s[M][N];
int n[M][N];
for(i=0;i<M;i++){
for(j=0;j<N;j++){
n[i][j]=0;
cin >> s[i][j];
if(s[i][j]=='*')
n[i][j]=-100;
}
}
for(i=0;i<M;i++){
for(j=0;j<N;j++){
if(n[i][j]<0)
for(m =(i==0?i:i-1) ;m<=(i==M-1?i:i+1);m++) // 核心代码,花式秀了一波操作,哈哈哈
for(k =(j==0?j:j-1);k<=(j==N-1?j:j+1);k++){
if(m==i&&k==j)
n[m][k]=-100;
else
n[m][k]+=1;
}
}
}
cout << "Field #"<<num <<":"<< endl;
for(i=0;i<M;i++){
for(j=0;j<N;j++){
if(n[i][j]<0)
cout << '*';
else
cout << n[i][j];
}
cout << endl;
}
cout << endl;
}
return 0;
}
0.0分
1 人评分
亲和的解法浏览:1060 |
C二级辅导-计负均正 (C++代码)浏览:898 |
拆分位数 (C语言代码)浏览:1328 |
printf基础练习2 (有点不明白)浏览:845 |
C语言程序设计教程(第三版)课后习题6.11 (C语言代码)浏览:549 |
C语言程序设计教程(第三版)课后习题8.5 (C语言代码)浏览:937 |
C语言考试练习题_一元二次方程 (C语言代码)浏览:576 |
DNA (C语言代码)浏览:540 |
1128题解(返回值为数组的情况)浏览:473 |
众数问题 (C语言代码)浏览:674 |