解题思路: 暴力枚举~

注意事项: !!!!Field  #1: 这个输出真的要注意!!!复制的field与#之间有两个空格!!!而答案里面只有一个空格!!!就是因为这个在提交的时候格式错误了好几次

参考代码:


import java.util.Scanner;

public class P1524 {
   public static void main(String[] args) {
       Scanner scanner = new Scanner(System.in);
       int n = 0, m = 0;
       n = scanner.nextInt();
       m = scanner.nextInt();
       int num = 1;
       while (n != 0 && m != 0){
           String s1 = scanner.nextLine();  //用来吸收空串
           String [][] AList = new String[n][m];  //n行m列
           for (int i = 0; i < n; i++) {
               char [] c0 = scanner.nextLine().toCharArray();
               for (int j = 0; j < m; j++) {
                   AList[i][j] = String.valueOf(c0[j]);
               }
           }


           String [][] result = solve(AList, n, m);
           System.out.println("Field #" + num + ":");
           for (int i = 0; i < n; i++) {
               for (int j = 0; j < m; j++) {
                   System.out.print(result[i][j]);
               }
               System.out.println("");
           }
           System.out.println("");

           num++;
           n = scanner.nextInt();
           m = scanner.nextInt();
       }
   }
   static String[][] solve(String [][] AList, int n, int m){

       String [][] boom = new String[n][m];
       for (int i = 0; i < n; i++) {
           for (int j = 0; j < m; j++) {
               int amount = 0;  //周遭炸弹数量
               String s0 = AList[i][j];  //取出一个字符
               if (s0.equals("*")){  //判断是否为炸弹,是则直接记录后进行下一个字符得到检测
                   boom[i][j] = "*";
                   continue;
               }
               //西北方向
               if (i - 1 >= 0 && j - 1 >= 0){
                   if (AList[i - 1][j - 1].equals("*")){
                       amount++;
                   }
               }
               //正北方向
               if (i - 1 >= 0){
                   if (AList[i - 1][j].equals("*")){
                       amount++;
                   }
               }
               //东北方向
               if (i - 1 >= 0 && j + 1 < m){
                   if (AList[i - 1][j + 1].equals("*")){
                       amount++;
                   }
               }
               //正东方向
               if (j + 1 < m){
                   if (AList[i][j + 1].equals("*")){
                       amount++;
                   }
               }
               //东南方向
               if (i + 1 < n && j + 1 < m){
                   if (AList[i + 1][j + 1].equals("*")){
                       amount++;
                   }
               }
               //正南方向
               if (i + 1 < n){
                   if (AList[i + 1][j].equals("*")){
                       amount++;
                   }
               }
               //西南方向
               if (i + 1 < n && j - 1 >= 0){
                   if (AList[i + 1][j - 1].equals("*")){
                       amount++;
                   }
               }
               //正西方向
               if (j - 1 >= 0){
                   if (AList[i][j - 1].equals("*")){
                       amount++;
                   }
               }
               boom[i][j] = String.valueOf(amount);
           }
       }
       return boom;
   }
}

点赞(0)
 

0.0分

0 人评分

C语言网提供由在职研发工程师或ACM蓝桥杯竞赛优秀选手录制的视频教程,并配有习题和答疑,点击了解:

一点编程也不会写的:零基础C语言学练课程

解决困扰你多年的C语言疑难杂症特性的C语言进阶课程

从零到写出一个爬虫的Python编程课程

只会语法写不出代码?手把手带你写100个编程真题的编程百练课程

信息学奥赛或C++选手的 必学C++课程

蓝桥杯ACM、信息学奥赛的必学课程:算法竞赛课入门课程

手把手讲解近五年真题的蓝桥杯辅导课程

评论列表 共有 0 条评论

暂无评论