atcoder#ABC219E. [ABC219E] Moat

[ABC219E] Moat

题目描述

xy xy -平面上のいくつかの点に村があります。
高橋君はこれらの村を民兵や魔女などの外敵から守るため、これらのすべての村を囲むようなお堀を建設します。

0 0 1 1 からなる 4 × 4 4\ \times\ 4 行列 A = (Ai, j) A\ =\ (A_{i,\ j}) が与えられます。
Ai, j = 1 A_{i,\ j}\ =\ 1 を満たす整数の組 (i, j) (i,\ j) (1  i, j  4) (1\ \leq\ i,\ j\ \leq\ 4) ごとに、座標 (i0.5, j0.5) (i-0.5,\ j-0.5) に村があります。

お堀は平面上の多角形です。 高橋君は以下の条件をすべて満たすお堀を建設します(入力例1・出力例1の説明も参考にして下さい)。

  1. 自己交差がない
  2. 内部にすべての村を含む
  3. すべての頂点の x x 座標と y y 座標は 0 0 以上 4 4 以下の整数
  4. すべての辺は x x 軸と y y 軸のどちらかに平行
  5. それぞれの内角の大きさは 90 90 度または 270 270

高橋君が建設するお堀として考えられるものが何通りあるかを出力して下さい。

输入格式

入力は以下の形式で標準入力から与えられる。

A1, 1 A_{1,\ 1} A1, 2 A_{1,\ 2} A1, 3 A_{1,\ 3} A1, 4 A_{1,\ 4} A2, 1 A_{2,\ 1} A2, 2 A_{2,\ 2} A2, 3 A_{2,\ 3} A2, 4 A_{2,\ 4} A3, 1 A_{3,\ 1} A3, 2 A_{3,\ 2} A3, 3 A_{3,\ 3} A3, 4 A_{3,\ 4} A4, 1 A_{4,\ 1} A4, 2 A_{4,\ 2} A4, 3 A_{4,\ 3} A4, 4 A_{4,\ 4}

输出格式

高橋君が建設するお堀として考えられるものが何通りあるかを出力せよ。

题目大意

有一个 4444 列的矩阵,由 0,10,1 构成。如果在第 (x,y)(x,y) 列是 11 ,那么在 (x0.5,y0.5)(x-0.5,y-0.5) 处有一座村庄。

现在你要修一个护城河,要保证:

  • 所有村庄都被包含在里面。
  • 护城河自身不能相交。
  • 只能有一条护城河。
  • 护城河每一条边必须与 x,yx,y 坐标平行,而且必须在线上。
  • 所有内角必须是 9090270270 度。

现在你要输出有多少种修筑护城河的方案。

1 0 0 0
0 0 1 0
0 0 0 0
1 0 0 0
1272
1 1 1 1
1 1 1 1
1 1 1 1
1 1 1 1
1

提示

制約

  • Ai, j  { 0, 1} A_{i,\ j}\ \in\ \lbrace\ 0,\ 1\rbrace
  • Ai, j = 1 A_{i,\ j}\ =\ 1 となる (i, j) (i,\ j) が少なくとも 1 1 つ存在する

Sample Explanation 1

下記の 2 2 つの画像の例は、高橋君が建設する**お堀の条件を満たします**。 ![](https://img.atcoder.jp/ghi/7b3181deb4e1df72e4c0661b1137db4d.png)![](https://img.atcoder.jp/ghi/a1e46c7db32d63942caa7119a4f3a593.png) 下記の 4 4 つの画像の例は、高橋君が建設する**お堀の条件を満たしません**。 ![](https://img.atcoder.jp/ghi/335053c01a13eb99e55767a3dc02eb38.png)![](https://img.atcoder.jp/ghi/c4df3d1fa24557b0d4d94ac0eaa8b9ab.png)![](https://img.atcoder.jp/ghi/be93de595e9222d5e20c90bd28d24563.png)![](https://img.atcoder.jp/ghi/37dac3af065c013ce0b8c0ee7591b97a.png) 上記の 4 4 つの例が高橋君の建設するお堀の条件を満たさない理由は、以下の通りです。 - 1 1 つ目の画像の例は、「自己交差がない」という条件を満たしません。 - 2 2 つ目の画像の例は、「内部にすべての村を含む」という条件を満たしません。 - 3 3 つ目の画像の例は、「すべての頂点の x x 座標と y y 座標は 0 0 以上 4 4 以下の整数」という条件を満たしません。(座標が整数でない頂点があります。) - 4 4 つ目の画像の例は、「すべての辺は x x 軸と y y 軸のどちらかに平行」という条件を満たしません。