正方形グリッドを等しい面積の部分に分割する


17

この課題は、次のパズルに基づいています。セルにマークが付いnnグリッドごとに与えられnます。あなたの仕事はn、各部分nが正確に1つのマークされたセルを含む正確なセルで構成される部分にグリッドを分割することです。

左側にパズルを、右側にその(ユニークな)ソリューションを示します。

パズル 解決

チャレンジ

n妥当な形式のゼロインデックス座標のセットが提供されます。

[(0,0), (0,3), (1,0), (1,1), (2,2)]

そして、あなたの仕事は、有効なパーティションを返すプログラムを作成することです(これも妥当な形式で)。

[
  [(0,0), (0,1), (0,2), (1,2), (1,3)],
  [(0,3), (0,4), (1,4), (2,4), (3,4)],
  [(1,0), (2,0), (3,0), (4,0), (4,1)],
  [(1,1), (2,1), (3,1), (3,2), (4,2)],
  [(2,2), (2,3), (3,3), (4,3), (4,4)]
]

パズルに解決策がない場合、プログラムはエラーをスローするか空の解決策を返すことでそれを示す必要があります。

入出力の例

[(0,0)]               => [[(0,0)]]

[(0,0), (1,1)]        => [
                          [(0,0), (1,0)], 
                          [(0,1), (1,1)]
                         ]

[(0,0), (0,1), (1,0)] => [] (no solution)

[(0,0), (0,1), (0,2)] => [
                          [(0,0), (1,0), (2,0)], 
                          [(0,1), (1,1), (2,1)],
                          [(0,2), (1,2), (2,2)],
                         ]

[(0,0), (0,2), (1,2)] => [
                          [(0,0), (1,0), (2,0)], 
                          [(0,1), (0,2), (1,1)],
                          [(1,2), (2,1), (2,2)],
                         ]

得点

これはなので、最短のコードが優先されます。


これは、Math Stack Exchangeの質問に触発されました。
ピーターカゲィ

@Arnauld、四角パズルのように見えます、「目的はグリッドを長方形と正方形のピースに分割することです」。この場合、そのような制約はありません。
ピーターカゲィ

混乱させて申し訳ありません。砂場のどこかに四角の挑戦があるかもしれないと思うか、多分私はある時点で自分で挑戦することを計画していた-確かに覚えていない。どちらにしても、一見同じことだと思いました。
アーナウルド

結果が2次元の座標配列であるのはなぜですか?そこで何が表現されているのか理解できません...配列のインデックスの2D配列にならないのですか?たとえば、行3、列2には、インデックス4の座標を持つパーティションが含まれていますか?
オリビエグレゴワール

例が示すように、参照座標から開始して各領域を描画できると仮定できますか?私は無意識のうちにこれを当たり前だと思っていることに気付いた。
アーナウルド

回答:


11

JavaScript(ES7)、166バイト

false

a=>(m=a.map(_=>[...a]),g=(n,X,Y,j=0,i)=>a[n]?a[j]?m.some((r,y)=>r.some((v,x)=>++v|(X-x)**2+(Y-y)**2-1?0:g(r[x]=n,x,y,j+1,i|x+[,y]==a[n])?1:r[x]=v)):i&&g(n+1):1)(0)&&m

オンラインでお試しください!

どうやって?

mN×NN

m = a.map(_ => [...a])

mNm++

gn(X,Y)ji

g = (n, X, Y, j = 0, i) => a[n] ? a[j] ? ... : i && g(n + 1) : 1

a[n]a[j]

gm

m.some((r, y) =>          // for each row r[] at position y in m[]:
  r.some((v, x) =>        //   for each cell of value v at position x in r[]:
    ++v |                 //     if this cell is already filled (i.e. v is numeric)
    (X - x) ** 2 +        //     or the squared Euclidean distance between
    (Y - y) ** 2 -        //     (X, Y) and (x, y)
    1 ?                   //     is not equal to 1:
      0                   //       this is an invalid target square: do nothing
    :                     //     else:
      g(                  //       do a recursive call to g:
        r[x] = n,         //         pass n unchanged and fill the cell with n
        x, y,             //         pass the coordinates of the current cell
        j + 1,            //         increment j
        i |               //         update i:
        x + [,y] == a[n]  //         set it if (x, y) = a[n]
      ) ?                 //       if the result of the call is truthy:
        1                 //         return 1
      :                   //       else:
        r[x] = v          //         reset the cell to NaN
  )                       //   end of inner map()
)                         // end of outer map()
弊社のサイトを使用することにより、あなたは弊社のクッキーポリシーおよびプライバシーポリシーを読み、理解したものとみなされます。
Licensed under cc by-sa 3.0 with attribution required.