 /
 /  
		
		Time Limit: 2 sec / Memory Limit: 1024 MiB
配点 : 400 点
問題文
H 行 W 列のマス目を考えます。上から r 番目、左から c 番目のマスを (r, c) と表すことにします。 全てのマスはそれぞれ白か黒のどちらかの色に塗られています。
次のような経路が存在するとき、このマス目を"良い"状態と呼びます。
- 常に白いマスの上にいながら、(1, 1) から、一つ 右か下 のマスに移動することを繰り返し、 (H, W) へ移動する。
ここで、"良い"状態ならば (1, 1) や (H, W) が必ず白いことに注意してください。
あなたの仕事は、以下の操作を繰り返し、マス目を"良い"状態にすることです。最小で何回操作を行う必要があるか求めてください。なお、有限回の操作で必ず"良い"状態に出来ることが証明可能です。
- 4 つの整数 r_0, c_0, r_1, c_1(1 \leq r_0 \leq r_1 \leq H, 1 \leq c_0 \leq c_1 \leq W) を選ぶ。r_0 \leq r \leq r_1, c_0 \leq c \leq c_1 を満たす全ての r, c について、(r, c) の色を変更する。つまり、白色ならば黒色にし、黒色ならば白色にする。
制約
- 2 \leq H, W \leq 100
入力
入力は以下の形式で標準入力から与えられる。
H W
s_{11} s_{12} \cdots s_{1W}
s_{21} s_{22} \cdots s_{2W}
 \vdots
s_{H1} s_{H2} \cdots s_{HW}
ここで、s_{rc} は # か . であり、# は (r, c) が黒色、. は白色であることを表す。
出力
最小の操作回数を出力せよ。
入力例 1
3 3 .## .#. ##.
出力例 1
1
(r_0, c_0, r_1, c_1) = (2, 2, 2, 2)、つまりマス (2, 2) のみ色を変更すれば良いです。
入力例 2
2 2 #. .#
出力例 2
2
入力例 3
4 4 ..## #... ###. ###.
出力例 3
0
操作が必要ない場合も存在します。
入力例 4
5 5 .#.#. #.#.# .#.#. #.#.# .#.#.
出力例 4
4
Score : 400 points
Problem Statement
Consider a grid with H rows and W columns of squares. Let (r, c) denote the square at the r-th row from the top and the c-th column from the left. Each square is painted black or white.
The grid is said to be good if and only if the following condition is satisfied:
- From (1, 1), we can reach (H, W) by moving one square right or down repeatedly, while always being on a white square.
Note that (1, 1) and (H, W) must be white if the grid is good.
Your task is to make the grid good by repeating the operation below. Find the minimum number of operations needed to complete the task. It can be proved that you can always complete the task in a finite number of operations.
- Choose four integers r_0, c_0, r_1, c_1(1 \leq r_0 \leq r_1 \leq H, 1 \leq c_0 \leq c_1 \leq W). For each pair r, c (r_0 \leq r \leq r_1, c_0 \leq c \leq c_1), invert the color of (r, c) - that is, from white to black and vice versa.
Constraints
- 2 \leq H, W \leq 100
Input
Input is given from Standard Input in the following format:
H W
s_{11} s_{12} \cdots s_{1W}
s_{21} s_{22} \cdots s_{2W}
 \vdots
s_{H1} s_{H2} \cdots s_{HW}
Here s_{rc} represents the color of (r, c) - # stands for black, and . stands for white.
Output
Print the minimum number of operations needed.
Sample Input 1
3 3 .## .#. ##.
Sample Output 1
1
Do the operation with (r_0, c_0, r_1, c_1) = (2, 2, 2, 2) to change just the color of (2, 2), and we are done.
Sample Input 2
2 2 #. .#
Sample Output 2
2
Sample Input 3
4 4 ..## #... ###. ###.
Sample Output 3
0
No operation may be needed.
Sample Input 4
5 5 .#.#. #.#.# .#.#. #.#.# .#.#.
Sample Output 4
4