#abc285g. [abc285_g]Tatami

[abc285_g]Tatami

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 1times11 \\times 1 tiles and 1times21 \\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 1times11 \\times 1 tile, and a square with 2 by a 1times21 \\times 2 tile. A square with ? may be covered by any kind of tile.

Determine if there is such a placement of tiles.

Constraints

  • 1leqH,Wleq3001 \\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,2ldotsc1,Wc_{1,1}c_{1,2}\\ldots c_{1,W} vdots\\vdots cH,1cH,2ldotscH,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.


Sample Input 1

3 4
2221
?1??
2?21

Sample Output 1

Yes

For example, the following placement satisfies the conditions.


Sample Input 2

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

Sample Output 2

No

There is no placement that satisfies the conditions.


Sample Input 3

5 5
11111
11111
11211
11111
11111

Sample Output 3

No