Есть ли горные кольца?

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 только краем, заполняя всю матрицу, исключая ячейки в коллекции, и никогда не проходя через ячейку в коллекции, необходимо пропустить хотя бы одну ячейку.

Истинные тестовые случаи

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].
HyperNeutrino
источник
Для чего nже третий «правдивый» тест на самом деле правдив? [1,2] ?
Эрик Outgolfer
@EriktheOutgolfer Кольцо 3-х примыкает к углу. Так да.
user202729

Ответы:

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.
Мистер Xcoder
источник
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.

Οurous
источник
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]))))

Попробуйте онлайн!

Проверяет, не вытекает ли граница из точки, не достигает границы, а граница может проходить до каждой точки

l4m2
источник