解题思路:
同1096题Minesweeper;
给原矩阵添加一圈(padding)即可避免判断是否在边缘的问题。
注意事项:
参考代码:
counter = 1 while 1: row, col = map(int, input().split()) if row == col == 0: break padding = ['.' for _ in range(col + 2)] field, mine = [padding, padding], [[0 for _ in range(col + 1)] for _ in range(row + 1)] for i in range(1, row + 1): field.insert(i, ['.'] + list(input()) + ['.']) for j in range(1, row + 1): for k in range(1, col + 1): if field[j][k] == '*': mine[j][k] = '*' else: temp = [field[j + 1][k + 1], field[j - 1][k - 1], field[j + 1][k - 1], field[j - 1][k + 1], field[j + 1][k], field[j - 1][k], field[j][k - 1], field[j][k + 1] ] mine[j][k] = sum(1 for i in temp if i == '*') print(f"Field #{counter}:") counter += 1 for i in range(1, row + 1): print(*mine[i][1:], sep='') print()
0.0分
0 人评分
C语言程序设计教程(第三版)课后习题6.1 (C语言代码)浏览:700 |
C语言程序设计教程(第三版)课后习题6.9 (C语言代码)浏览:1052 |
C语言程序设计教程(第三版)课后习题1.5 (C语言代码)浏览:541 |
C语言程序设计教程(第三版)课后习题6.3 (C++代码)浏览:1067 |
C语言程序设计教程(第三版)课后习题6.3 (C语言代码)浏览:687 |
第三届阿里中间件性能挑战赛-总决赛亚军比赛攻略浏览:1170 |
C语言程序设计教程(第三版)课后习题10.2 (C语言代码)浏览:560 |
幸运数 (C++代码)浏览:2982 |
素数的个数 一直是超时浏览:698 |
C语言程序设计教程(第三版)课后习题5.4 (C语言代码)浏览:596 |