atcoder#ABC285G. [ABC285G] Tatami

[ABC285G] Tatami

Score : 600600 points

Problem Statement

We have a grid with HH horizontal rows and WW vertical columns. We denote by square (i,j)(i,j) the square at the ii-th row from the top and jj-th column from the left.

We want to cover this grid with 1×11 \times 1 tiles and 1×21 \times 2 tiles so that no tiles overlap and everywhere is covered by a tile. (A tile can be rotated.)

Each square has 1, 2, or ? written on it. The character written on square (i,j)(i, j) is ci,jc_{i,j}. A square with 1 written on it must be covered by a 1×11 \times 1 tile, and a square with 2 by a 1×21 \times 2 tile. A square with ? may be covered by any kind of tile.

Determine if there is such a placement of tiles.

Constraints

  • 1H,W3001 \leq H,W \leq 300
  • HH and WW are integers.
  • ci,jc_{i,j} is one of 1, 2, and ?.

Input

The input is given from Standard Input in the following format:

HH WW

c1,1c1,2c1,Wc_{1,1}c_{1,2}\ldots c_{1,W}

\vdots

cH,1cH,2cH,Wc_{H,1}c_{H,2}\ldots c_{H,W}

Output

Print Yes if there is a placement of tiles to satisfy the conditions in the Problem Statement; print No otherwise.

3 4
2221
?1??
2?21
Yes

For example, the following placement satisfies the conditions.

3 4
2?21
??1?
2?21
No

There is no placement that satisfies the conditions.

5 5
11111
11111
11211
11111
11111
No