~

# Replicate Replicate Rfplicbte

The owner of the Automatic Cellular Manufacturing corporation has just patented a new process for the mass production of identical parts. Her approach uses a two-dimensional lattice of two-state cells, each of which is either “empty” or “filled.” The exact details are, of course, proprietary.

Initially, a set of cells in the lattice is filled with a copy of the part that is to be reproduced. In a sequence of discrete steps, each cell in the lattice simultaneously updates its state by examining its own state and those of its eight surrounding neighbors. If an odd number of these nine cells are filled, the cell’s state in the next time step will be filled, otherwise it will be empty. Figure 1 shows several steps in the replication process for a simple pattern consisting of three filled cells.

However, a bug has crept into the process. After each update step, one cell in the lattice might spontaneously flip its state. For instance, Figure 2 shows what might happen if a cell flipped its state after the first time step and another flipped its state after the third time step.

Unfortunately, the original patterns were lost, and only the (possibly corrupted) results of the replication remain. Can you write a program to determine a smallest possible nonempty initial pattern that could have resulted in a given final pattern?

## Input

The first line of input contains two integers [Math Processing Error]w ([Math Processing Error]1≤w≤300) and [Math Processing Error]h ([Math Processing Error]1≤h≤300), where [Math Processing Error]w and [Math Processing Error]h are the width and height of the bounding box of the final pattern. Following that are [Math Processing Error]h lines, each containing [Math Processing Error]w characters, giving the final pattern. Each character is either ‘.’  (representing an empty cell) or ‘#’ (representing a filled cell). There is at least one filled cell in the first row, in the last row, in the first column, and in the last column.

## Output

Display a minimum-size nonempty pattern that could have resulted in the given pattern, assuming that at each stage of the replication process at most one cell spontaneously changed state. The size of a pattern is the area of its bounding box. If there is more than one possible minimum-size nonempty starting pattern, any one will be accepted. Use the character ‘.’ for empty cells and ‘#’ for filled cells. Use the minimum number of rows and columns needed to display the pattern.

Sample Input 1Sample Output 1
10 10
.#...#...#
##..##..##
##.#.##...
##.#.##...
.#...#####
...##..#.#
......###.
##.#.##...
#..#..#..#
##..##..##

.#
##

Sample Input 2Sample Output 2
8 8
##..#.##
#.####.#
.#.#.#..
.##.#.##
.#.#.#..
.##.#.##
#..#.###
##.#.##.

####
#..#
#.##
###.

Sample Input 3Sample Output 3
5 4
#....
..###
..###
..###

#


#### ACM-ICPC World Finals 2017 - Need for Speed

2018-04-13 17:59:05

#### nyoj-484-The Famous Clock

2014-12-13 18:05:52

#### 2017-2018 ACM-ICPC, NEERC, Northern Subregional Contest(Dividing Marbles-构造)

2017-11-15 06:10:23

#### 2015 ACM-ICPC World Finals - Marrakech 题解(待续)

2016-12-09 17:22:27

#### [World Final 2017 F] Posterize (DP)

2017-05-25 22:09:29

#### FROM BAYLOR TO BAYLOR

2014年12月25日 10.97MB 下载

#### 2017 ACM-ICPC ECL-FINAL 部分代码

2017-12-18 15:06:52

#### ACM-ICPC World Finals 世界总决赛 1990 - 2010 题目册

2013年08月03日 5.37MB 下载

#### ACM-ICPC World Finals 世界总决赛 2011 题目和测试数据

2013年08月08日 17.7MB 下载

#### ACM-ICPC World Finals 世界总决赛 2012 题目和测试数据

2013年08月03日 6.87MB 下载