Розділіть квадратну сітку на частини рівної площі


17

Це завдання заснована на наступній головоломці: Вам дається nпо nсітці з nклітинами , позначених. Ваше завдання полягає в тому, щоб розділити сітку на nчастини, де кожна частина складається саме з nкомірок, кожна з яких містить точно одну позначену клітинку.

Приклад

Ось головоломка зліва та її (унікальне) рішення справа:

пазл рішення

Виклик

Вам буде наданий набір 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)],
                         ]

Оцінка балів

Це , тому найкоротший код виграє.



@Arnauld, це виглядає як для загадок Шикаку, "мета - розділити сітку на прямокутні та квадратні частини". У цьому випадку такого обмеження немає.
Петро Кагей

Вибачте за непорозуміння. Я думаю, що десь у пісочниці може виникнути виклик Шикаку, або, можливо, я в якийсь момент я планував зробити себе - я не можу точно згадати. Так чи інакше, я подумав, що це те саме на перший погляд.
Арнольд

Чому результат 2d масив координат? Я не розумію, що там виражається ... Чи не може це бути 2d масив індексу масиву? Наприклад, рядок 3, стовпець 2 містить розділ з координатами в індексі 4?
Олів'є

Чи можемо ми припустити, що кожну область можна намалювати, починаючи з опорних координат, як це приклад пропонує? Я щойно зрозумів, що несвідомо сприйняв це як належне.
Арнольд

Відповіді:


11

JavaScript (ES7), 166 байт

fалсе

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

Спробуйте в Інтернеті!

Як?

мN×NN

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

мNм++

гн(Х,Y)ji

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

а[н]а[j]

гм

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()
Використовуючи наш веб-сайт, ви визнаєте, що прочитали та зрозуміли наші Політику щодо файлів cookie та Політику конфіденційності.
Licensed under cc by-sa 3.0 with attribution required.