解题思路:开辟空间的时候行和列都+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语言训练-斐波纳契数列 (C语言代码)浏览:774 |
C语言程序设计教程(第三版)课后习题7.5 (C语言代码)浏览:577 |
【回文数(二)】 (C语言代码)浏览:851 |
蓝桥杯历届试题-九宫重排 (C++代码)浏览:2782 |
wu-理财计划 (C++代码)浏览:827 |
C语言程序设计教程(第三版)课后习题6.9 (C语言代码)浏览:624 |
C语言程序设计教程(第三版)课后习题6.3 (C语言代码)from DQM浏览:652 |
C语言程序设计教程(第三版)课后习题10.3 (C语言代码)浏览:1908 |
核桃的数量 (C语言代码)浏览:870 |
Pascal三角 (C语言代码)浏览:641 |