不甘堕落


私信TA

用户名:wangxu2022

访问量:800

签 名:

码界难民一枚~

等  级
排  名 831
经  验 3641
参赛次数 0
文章发表 8
年  龄 0
在职情况 学生
学  校 宁波大学科学技术学院
专  业

  自我简介:

题目: https://www.dotcpp.com/oj/problem1096.html


思路:作图,暴力完事


代码:

#include<stdio.h>

int main(){

int a,b,i,j,count,c=0;

char map[100][100],explore[100][100]={0};

while(1){

scanf("%d %d",&a,&b);

getchar();

if(a==0&&b==0) break;

c++;

printf("Field #%d:\n",c);

//第一步:输入

for(i=0;i<a;i++){

for(j=0;j<b;j++){

scanf("%c",&map[i][j]);

}

getchar();

}

//第二步:创建 + 暴力

for(i=0;i<a;i++){

for(j=0;j<b;j++){

count = 0;

if(map[i][j]=='*') explore[i][j]='*';

else{                                                                                                        //8个方向都考虑

if((i-1>=0)&&(j-1>=0)&&(map[i-1][j-1]=='*')) count++;

if((i-1>=0)&&(map[i-1][j]=='*')) count++;

if((i-1>=0)&&(j+1<b)&&(map[i-1][j+1]=='*')) count++;

if((j-1>=0)&&(map[i][j-1]=='*')) count++;

if((j+1<=b)&&(map[i][j+1]=='*')) count++;

if((i+1

if((i+1<=a)&&(map[i+1][j]=='*')) count++;

if((i+1<=a)&&(j+1<=b)&&(map[i+1][j+1]=='*')) count++; 

explore[i][j]=count;

}

}

}

//第三步:输出

for(i=0;i<a;i++){

for(j=0;j<b;j++){

if(explore[i][j]=='*')

printf("%c",explore[i][j]);

else 

printf("%d",explore[i][j]);

}

printf("\n");

}

printf("\n");

}

return 0;

}


 

0.0分

0 人评分

  评论区

  • «
  • »