2371. Nurikabe

单点时限: 2.0 sec

内存限制: 256 MB

Your goal is to write a solver for Nurikabe, a binary determination puzzle. The puzzle is played on a grid, typically rectangular (with no standard size) containing empty and numbered cells. You must decide for each cell if it is white (land) or black (water), so that it satisfies the following constraints. An Island is a maximal connected region of white cells.

  1. The water areas must form one connected region. (All the black cells must be connected.)
  2. Each numbered cell must be part of an island.
  3. The number of cells in an island is equal to the number it contains.
  4. Every region (island) of white cells (land) must contain exactly one number.
  5. Two islands may not be connected.
  6. 2x2 blocks of black squares are not allowed.

Note that diagonal adjacency doesn’t count as connectedness. You can assume there is always a unique solution for each puzzle.

输入格式

There are multiple test cases in the input. The first line of each test case contains two numbers n, m (3 ≤ n,m ≤ 9) which are the dimensions of the puzzle, followed by n lines each one has m characters including ‘.’ (indicating an empty cell) and 1-digit numbers. The last line of the input contains two zero numbers.

输出格式

The output for each test case should show the solved puzzle. Show black (water) cells with ‘#’. Write an empty line in the output after each puzzle.

样例

Input
3 4
3...
....
.4..
5 5
2.5..
.....
.....
.....
..4.3
0 0
Output
3..#
####
.4..
2#5..
.#.##
##.#.
.###.
..4#3

1 人解决,3 人已尝试。

1 份提交通过,共有 8 份提交。

9.9 EMB 奖励。

创建: 16 年,2 月前.

修改: 7 年,2 月前.

最后提交: 3 年,12 月前.

来源: Tehran 2007-2008

题目标签