解题思路:开辟空间的时候行和列都+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 人评分
2006年春浙江省计算机等级考试二级C 编程题(2) (C语言代码)浏览:503 |
K-进制数 (C语言描述,蓝桥杯)浏览:955 |
C语言程序设计教程(第三版)课后习题9.8 (C语言代码)浏览:672 |
分糖果 (C语言代码)浏览:980 |
C语言程序设计教程(第三版)课后习题6.3 (C语言代码)浏览:494 |
C语言程序设计教程(第三版)课后习题5.8 (C语言代码)浏览:692 |
10月月赛题解浏览:554 |
幸运数 (C++代码)浏览:2982 |
C语言程序设计教程(第三版)课后习题8.7 (C语言代码)浏览:538 |
判定字符位置 (C++代码)浏览:733 |