解题思路:开辟空间的时候行和列都+2,将矩阵放中间,画了个简略的草图
参考代码:
import java.util.Scanner; public class Main { public static void main(String[] args) { Scanner sc = new Scanner(System.in); int c = 0; //统计当前是第几个矩阵 while (true) { int n = sc.nextInt(); int m = sc.nextInt(); if (m == 0 && n == 0) break; int[][] arr = new int[n + 2][m + 2]; //在矩阵周围开辟一圈空间,将矩阵放中间 for (int i = 1; i < arr.length - 1; i++) { char[] chs = sc.next().toCharArray(); for (int j = 0; j < chs.length; j++) { arr[i][j + 1] = chs[j] == '*' ? 1 : 0; //将输入的字符转换为0和1,方便计算,雷为1 } } System.out.println("Field #" + ++c + ":"); for (int i = 1; i < arr.length - 1; i++) { for (int j = 1; j < arr[i].length - 1; j++) { if (arr[i][j] == 1) { System.out.print('*'); } else { int count = 0; //累加周围一圈,因为矩阵周围有一圈0占位,所以不用担心越界问题 count += arr[i - 1][j - 1]; count += arr[i - 1][j]; count += arr[i - 1][j + 1]; count += arr[i][j - 1]; count += arr[i][j + 1]; count += arr[i + 1][j - 1]; count += arr[i + 1][j]; count += arr[i + 1][j + 1]; System.out.print(count); } } System.out.println(); } System.out.println(); } sc.close(); } }
0.0分
2 人评分
C语言程序设计教程(第三版)课后习题6.11 (C++代码)(有个库函数叫sqrt)浏览:867 |
C二级辅导-计负均正 (C语言代码)浏览:593 |
买不到的数目 (C++代码)浏览:868 |
不容易系列 (C语言代码)浏览:669 |
C语言训练-排序问题<1> (C语言代码)浏览:601 |
用筛法求之N内的素数。 (C语言代码)浏览:1260 |
2004年秋浙江省计算机等级考试二级C 编程题(1) (C语言代码)浏览:506 |
哥德巴赫曾猜测 (C语言代码)浏览:2350 |
1113题解浏览:789 |
1013题解浏览:560 |