atcoder#AGC033D. [AGC033D] Complexity
[AGC033D] Complexity
Score : points
Problem Statement
Note the unusual memory limit.
For a rectangular grid where each square is painted white or black, we define its complexity as follows:
- If all the squares are black or all the squares are white, the complexity is .
- Otherwise, divide the grid into two subgrids by a line parallel to one of the sides of the grid, and let and be the complexities of the subgrids. There can be multiple ways to perform the division, and let be the minimum value of in those divisions. The complexity of the grid is .
You are given a grid with horizontal rows and vertical columns where each square is painted white or black.
characters from to represent the colors of the squares.
is #
if the square at the -th row from the top and the -th column from the left is black, and is .
if that square is white.
Find the complexity of the given grid.
Constraints
- is
#
or.
.
Input
Input is given from Standard Input in the following format:
Output
Print the complexity of the given grid.
3 3
...
.##
.##
2
Let us divide the grid by the boundary line between the first and second columns. The subgrid consisting of the first column has the complexity of , and the subgrid consisting of the second and third columns has the complexity of , so the whole grid has the complexity of at most .
6 7
.####.#
#....#.
#....#.
#....#.
.####.#
#....##
4