Вам будет дан двумерный массив целых чисел A и длина N. Ваша задача - найти в массиве прямую линию (горизонтальную, вертикальную или диагональную) из N элементов, которая дает наибольшую общую сумму, и вернуть эту сумму ,
пример
N = 3, A =
3 3 7 9 3
2 2 10 4 1
7 7 2 5 0
2 1 4 1 3
Этот массив имеет 34 допустимых строки, в том числе
Vertical
[3] 3 7 9 3
[2] 2 10 4 1
[7] 7 2 5 0
2 1 4 1 3 [3,2,7] = 12
Horizontal
3 3 7 9 3
2 2 10 4 1
7 7 [2] [5] [0]
2 1 4 1 3 [2,5,0] = 7
Diagonal
3 3 [7] 9 3
2 2 10 [4] 1
7 7 2 5 [0]
2 1 4 1 3 [7,4,0] = 11
Максимальная линия
3 3 7 [9] 3
2 2 [10] 4 1
7 [7] 2 5 0
2 1 4 1 3 [7,10,9] = 26
Примечание: строки могут не обтекать края массива.
входные
- AX by Y 2-D массив A, с X, Y> 0. Каждый элемент массива содержит целочисленное значение, которое может быть положительным, нулевым или отрицательным. Вы можете принять этот массив в альтернативном формате (например, список 1-D массивов), если хотите.
- Одно положительное целое число N, не больше max (X, Y).
Выход
- Одно значение, представляющее максимальную сумму строки, которая может быть найдена в массиве. Обратите внимание, что вам не нужно указывать отдельные элементы этой линии или места ее расположения.
Контрольные примеры
N = 4, A =
-88 4 -26 14 -90
-48 17 -45 -70 85
22 -52 87 -23 22
-20 -68 -51 -61 41
Output = 58
N = 4, A =
9 4 14 7
6 15 1 12
3 10 8 13
16 5 11 2
Output = 34
N = 1, A =
-2
Output = -2
N = 3, A =
1 2 3 4 5
Output = 12
N = 3, A =
-10 -5 4
-3 0 -7
-11 -3 -2
Output = -5
code-golf
array-manipulation
matrix
user2390246
источник
источник
[[-10, -5, 4],[-3, 0, -7],[-11,-3,-2]]
->-5
(4 + -7 + -2
)Ответы:
Желе , 15 байт
Попробуйте онлайн!
Как это устроено
источник
¥
там ...$
создает монаду изZṚ
, в то время как¥
создает диаду, изZṚ
которой возвращает результат той же функции (поворот на 90 против часовой стрелки), примененной к его левому операнду. Который соответствует шаблону+ ×
и оцениваетv+(λ×ρ)
(именноv = v , (M ZṚ¥ n)
в этом случае). Однако просто использование$
не работает, потому что+ F
в диадической цепочке нет шаблона.Wolfram Language (Mathematica) , 73 байта
Попробуйте онлайн!
Как это устроено
Берет сначала
N
а потом матрицуA
качестве ввода.Join@@Partition[#2,{#,#},1,1,-∞]
находит каждый сN
помощьюN
подматрицы матрицыA
, дополняется ,-∞
где это необходимо , чтобы гарантировать , что бегущие строчки из сетки будет из бега.Для каждого из этих блоков мы вычисляем
Tr/@Join[#,#,{#,Reverse@#}]
: след (то есть сумму) каждой строки, след (то есть сумму) каждого столбца, след ( фактически след, впервые в истории игры в коде Mathematica) блока и след блока перевернулся.#
являетсяTranspose@#
.Тогда мы найдем
Max
все это.источник
Max@BlockMap[Tr/@Join[#,#,{#,Reverse@#}]&,#2,{#,#},1]&
также работает. Но нам нужно дополнить его-∞
для обработки случаев, когда вA
нем меньшеN
строк или столбцов, иBlockMap
он не поддерживает заполнение.\[Transpose]
) можно ввести как\:f3c7
.Tr
используется как след.Tr
следа матрицы уже подходило раньше, но это все еще редко и удивительно.Mathematica,
135123 байтаПопробуйте онлайн!
источник
Diagonal[s,#]
доs~Diagonal~#
и{{Transpose@#,#2},{Reverse@#,#2}}
в{#|#2,Reverse@#|#2}
. (Непечатаемая является U + F3C7 =\[Transpose]
; TIO , кажется, не так, хотя альтернатива:.{Transpose@#|#2,Reverse@#|#2}
)\[Transpose]
или\:f3c7
(по крайней мере, последний корочеThread@
). Однако, если ответ - Mathematica REPL (не скрипт Mathematica), вы можете принять 3-байтовое решение.Желе , 16 байт
Попробуйте онлайн!
источник
µ;Z;UŒD$;ŒDṡ€⁴ẎS€Ṁ
JavaScript,
151129 байтФункция Curry принимает два аргумента, первый - массив массивов чисел, второй - число.
Благодаря Арно , сэкономьте 20+ байтов.
Показать фрагмент кода
источник
1/s
вместоs==s
должен работать как положено.(s=(g=...)(n))>m?s:m
чтобы(g=...)(n)>m?g(n):m
сохранить 1 байт.Jq 1,5 , 211 байт
Ожидает ввода в
N
иA
, например:расширенный
Обратите внимание, что эта задача в основном такая же, как проблема Project Euler 11
Попробуйте онлайн!
источник
Python 2 ,
208184183176 байт-float("inf")
представления, что проверенная строка вышла за пределы матрицы вместо вычисления отрицательной суммы всех элементов матрицы.R,L=range,len
сокращения встроенных функций и использованияy in R(L(A))...R(L(A[y]))
вместоy,Y in e(A)...x,_ in e(Y)
.float("inf")
в гольф9e999
.Попробуйте онлайн!
объяснение
источник
R , 199 байт
Попробуйте онлайн!
Рекурсивное решение. Для каждого элемента (i, j) матрицы он возвращает max между суммой по строке, суммой по столбцу, суммой по диагонали и результатом функции, примененной к (i + 1, j), и (I, J + 1). Результаты для тестовых случаев показаны в TIO.
источник
Шелуха , 14 байт
Попробуйте онлайн!
Благодаря новым встроенным антисиагоналам, это довольно короткий ответ :)
источник
JavaScript 170 байт
все еще вайп на части гольфа добавил еще 4 символа, потому что я не управлял случаем, где максимум отрицателен, и N больше чем 1
источник
G=
не учитывается)a||M,b||M,c||M,d||M
вместоa,b,c,d
?Python 2 ,
222218 байтПопробуйте онлайн!
источник