Amber Claes Maes, a patissier, opened her own shop last month.
She decided to submit her work to the International Chocolate
Patissier Competition to promote her shop, and she
was pursuing a recipe of sweet chocolate bars.
After thousands of trials, she finally reached the recipe.
However, the recipe required high skill levels to form chocolate to
an orderly rectangular shape.
Sadly, she has just made another strange-shaped chocolate bar as shown in
Figure G-1.
Figure G-1: A strange-shaped chocolate bar
Each chocolate bar consists of many small rectangular segments
of chocolate.
Adjacent segments are separated with a groove in
between them for ease of snapping.
She planned to cut the strange-shaped chocolate bars into several
rectangular pieces and sell them in her shop.
She wants to cut each chocolate bar as follows.
- The bar must be cut along grooves.
- The bar must be cut into rectangular pieces.
- The bar must be cut into as few pieces as possible.
Following the rules, Figure G-2 can be an instance of cutting of
the chocolate bar shown in Figure G-1. Figures G-3 and G-4
do not meet the rules; Figure G-3 has
a non-rectangular piece, and Figure G-4 has more pieces
than Figure G-2.
Figure G-2: An instance of cutting that follows the rules
Figure G-3: An instance of cutting that leaves a non-rectangular piece
Figure G-4: An instance of cutting that yields more pieces than Figure G-2
Your job is to write a program that computes the number of pieces
of chocolate after cutting according to the rules.
The input is a sequence of datasets. The end of the input is indicated by
a line containing two zeros separated by a space. Each dataset is
formatted as follows.
h w
r(1, 1) ... r(1, w)
r(2, 1) ... r(2, w)
...
r(h, 1) ... r(h, w)
The integers
h and
w are the lengths of the two orthogonal
dimensions of the chocolate, in number of segments.
You may assume that 2 ≤
h ≤ 100 and 2 ≤
w ≤ 100.
Each of the following
h
lines consists of
w characters, each is either a
"
." or a "
#". The character
r(i, j) represents whether
the chocolate segment exists at the position (
i,
j )
as follows.
- ".": There is no chocolate.
- "#": There is a segment of chocolate.
You can assume that there is no dataset that represents
either multiple disconnected bars as depicted in Figure G-5
or a bar in a shape with hole(s) as depicted in Figure G-6
and G-7. You can also assume that there is at least one "
#"
character in each dataset.
Figure G-5: Disconnected chocolate bars
Figure G-6: A chocolate bar with a hole
Figure G-7: Another instance of a chocolate bar with a hole