Чи є гірські кільця?


14

Виклик

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

Візьмемо простий приклад:

3 4 5 3
3 1 2 3
4 2 1 3
4 3 6 5

Якщо ми встановлюємо nв 2:

1 1 1 1
1 0 0 1
1 0 0 1
1 1 1 1

Як ми добре бачимо, 1s по краю утворюють кільце.

Ми визначаємо кільце як упорядковану колекцію комірок, де сусідні комірки в колекції також є сусідніми (край або кут) на сітці. Крім того, кільце повинно містити щонайменше 1 клітинку всередині нього; тобто спроба BFS-заливки лише краєм всієї матриці, виключаючи комірки в колекції і ніколи не проходячи до комірки в колекції, повинна пропустити щонайменше одну клітинку.

Випадки тестування на truthy

4 7 6 5 8 -> 1 1 1 1 1
6 2 3 1 5 -> 1 0 0 0 1 (n = 3)
6 3 2 1 5 -> 1 0 0 0 1
7 5 7 8 6 -> 1 1 1 1 1

1 3 2 3 2
1 6 5 7 2
1 7 3 7 4
1 6 8 4 6

1 3 1
3 1 3
1 3 1

7 5 8 7 5 7 8 -> if you have n = 4, you get an interesting ridge shape around the top and right of the grid
8 4 4 2 4 2 7
6 1 8 8 7 2 7
5 4 7 2 5 3 5
5 6 5 1 6 4 5
3 2 3 2 7 4 8
4 4 6 7 7 2 5
3 2 8 2 2 2 8
2 4 8 8 6 8 8

5 7 6 8 6 8 7 -> there is an island in the outer ring (n = 4), but the island is a ring
5 3 2 4 2 4 7
6 3 7 8 5 1 5
8 2 5 2 8 2 7
8 3 8 8 8 4 7
6 1 4 1 1 2 8
5 5 5 5 7 8 7

150 170 150
170 160 170
150 170 150

Випробування фальшивих справ

1 2 3 2 1 -> this is just a single mountain if you picture it graphcially
2 3 4 3 2
3 4 5 4 3
2 3 4 3 2
1 2 3 2 1

4 5 4 3 2 -> this is an off-centered mountain
5 6 5 4 3
4 5 4 3 2
3 4 3 2 1

1 1 1 1 1 -> this is four mountains, but they don't join together to form a ring
1 2 1 2 1
1 1 1 1 1
1 2 1 2 1
1 1 1 1 1

3 3 3 3 3 -> there is a ring formed by the `3`s, but the `4` in the middle is taller so it doesn't qualify as a mountain ring
3 1 1 1 3
3 1 4 1 3
3 1 1 1 3
3 3 3 3 3

3 4 4 4 3
4 4 3 4 4
3 3 3 3 4
4 4 3 4 4
3 4 4 4 3

1  2  3  4  5
6  7  8  9  10
11 12 13 14 15
16 17 18 19 20
22 23 24 25 26

Правила

  • Застосовуються стандартні лазівки
  • Це , тому найкоротша відповідь у байтах кожною мовою оголошується переможцем своєї мови. Відповіді не приймаються.
  • Вхід може бути прийнятий як будь-яка розумна форма для матриці натуральних чисел
  • Вихід може бути заданий у вигляді будь-яких двох розумних, послідовних, чітких значень, що вказують на [true] або [false].

Бо що nтаке третій «простий» тест-випадок насправді truthy? [1,2] ?
Ерік Аутгольфер

@EriktheOutgolfer Кільце з 3-х сусідніх за кутом. Отже, так.
користувач202729

Відповіді:


3

Желе , 38 байт

Ẇ€Z$⁺Ẏµ,ZẈ>2ẠµƇµḊṖZƊ⁺FṀ<,Z.ịḊṖ$€Ɗ€ƊȦ)Ṁ

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

Виводи 1, якщо матриця містить гірські масиви, 0 в іншому випадку.

Як це працює (трохи застаріло)

Можливо, я зможу трохи скоротити код, тому цей розділ, ймовірно, зазнає значного редагування.

Посилання-помічник

,Z.ịḊṖ$€Ɗ€ – Helper link. Let S be the input matrix.
,Z         – Pair S with its transpose.
        Ɗ€ – For each matrix (S and Sᵀ), Apply the previous 3 links as a monad.
  .ị       – Element at index 0.5; In Jelly, the ị atom returns the elements at
             indices floor(x) and ceil(x) for non-integer x, and therefore this
             returns the 0th and 1st elements. As Jelly is 1-indexed, this is the
             same as retrieving the first and last elements in a list.
    ḊṖ$€   – And for each list, remove the first and last elements.

Наприклад, задана матриця у вигляді:

A(1,1) A(1,2) A(1,3) ... A(1,n)
A(2,1) A(2,2) A(2,3) ... A(2,n)
A(3,1) A(3,2) A(3,3) ... A(3,n)
...
A(m,1) A(m,2) A(m,3) ... A(m,n)

Це повертає масиви (порядок не має значення):

A(1,2), A(1,3), ..., A(1,n-1)
A(m,2), A(m,3), ..., A(m,n-1)
A(2,1), A(3,1), ..., A(m-1,1)
A(2,n), A(3,n), ..., A(m-1,n)

Якщо коротко розповісти, це створює найвіддаленіші рядки та стовпці, кути яких видалено.

Основна ланка

Ẇ€Z$⁺Ẏµ,ZẈ>2ẠµƇµḊṖZƊ⁺FṀ<ÇȦ)Ṁ – Main link. Let M be the input matrix.
Ẇ€                           – For each row of M, get all its sublists.
  Z$                         – Transpose and group into a single link with the above.
    ⁺                        – Do twice. So far, we have all contiguous sub-matrices.
     Ẏ                       – Flatten by 1 level.
      µ      µƇ              – Filter-keep those that are at least 3 by 3:
       ,Z                      – Pair each sub-matrix S with Sᵀ.
         Ẉ                     – Get the length of each (no. rows, no. columns).
          >2                   – Element-wise, check if it's greater than 2.
            Ạ                  – All.
               µ          )  – Map over each sub-matrix S that's at least 3 by 3
                ḊṖ           – Remove the first and last elements.
                  ZƊ         – Zip and group the last 3 atoms as a single monad.
                    ⁺        – Do twice (generates the inner cells).
                     FṀ      – Flatten, and get the maximum.
                       <Ç    – Element-wise, check if the results of the helper
                               link are greater than those in this list.
                         Ȧ   – Any and all. 0 if it is empty, or contains a falsey
                               value when flattened, else 1.
                           Ṁ – Maximum.

2

Чистота , 224 ... 161 байт

import StdEnv,StdLib
p=prod
~ =map
^ =reverse o$
@ =transpose o~(^o^)
$l=:[h:t]|h>1=l=[1: $t]
$e=e
?m=p[p(~p(limit(iterate(@o@)(~(~(\a|a>b=2=0))m))))\\n<-m,b<-n]

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

Визначає функцію ? :: [[Int]] -> Int, повертаючи, 0якщо є дзвінок, та 1інше.

Працює, перетворюючи матрицю в 2s для гір і 0s для долин, потім затоплюючи з 1s, поки результат не перестане змінюватися. Якщо 0для будь-якої висоти гори все ще існує, продукт буде 0.


1

JavaScript (Node.js) , 302 байти

a=>a.some((b,i)=>b.some((n,j)=>(Q=(W=(i,j,f)=>[a.map((b,I)=>b.map((t,J)=>I==i&J==j)),...a+0].reduce(A=>A.map((b,I)=>b.map((t,J)=>f(I)(J)&&(A[I-1]||b)[J]|(A[I+1]||b)[J]|b[J-1]|b[J+1]|t))))(i,j,I=>J=>a[I][J]<=n)).some((b,i)=>b.some((d,j)=>d&&!i|!j|!Q[i+1]|b[j+1]==b.b))<!/0/.test(W(0,0,I=>J=>!Q[I][J]))))

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

Перевіряє, чи течія з точки не може досягти кордону, тоді як кордон може ходити до кожної точки

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