Вам дана квадратная матрица шириной , содержащая квадратные числа .
Ваша задача - заставить все квадратные числа «взорваться», пока все они не исчезнут. Вы должны распечатать или вернуть окончательную матрицу.
Более конкретно:
- Ищите самый высокий квадрат в матрице.
- Ищите его наименьшего соседа (по горизонтали или вертикали и без обтекания).
- Замените на x и замените n на n × x .
Повторите процесс с шага 1, пока в матрице больше не будет квадрата.
пример
Матрица ввода:
Самый высокий квадрат взрывается в две части и сливается со своим наименьшим соседом, который становится:
Самая высокая площадь взрывается и сливается со своим самым маленьким соседом :
Самый высокий квадрат взрывается и сливается со своим самым маленьким соседом :
Единственный оставшийся квадрат взрывается и сливается со своим самым маленьким соседом :
Там больше нет квадрата, поэтому мы закончили.
правила
- Входная матрица гарантированно имеет следующие свойства:
- на каждом шагу самая высокая площадь всегда будет уникальной
- на каждом шаге самый маленький сосед самой высокой площади всегда будет уникальным
- последовательность не будет повторяться вечно
- Исходная матрица может содержать , но вам не нужно беспокоиться о том, чтобы сделать взрыв, так как он никогда не будет самым высоким или единственным оставшимся квадратом.
- Ввод / вывод может быть обработан в любом разумном формате
- Это код-гольф
Контрольные примеры
Input : [[16,9],[4,25]]
Output: [[24,6],[20,5]]
Input : [[9,4],[1,25]]
Output: [[3,12],[5,5]]
Input : [[625,36],[196,324]]
Output: [[750,540],[14,252]]
Input : [[1,9,49],[1,4,1],[36,25,1]]
Output: [[3,6,7],[6,2,7],[6,5,5]]
Input : [[81,4,64],[16,361,64],[169,289,400]]
Output: [[3,5472,8],[624,323,1280],[13,17,20]]
Input : [[36,100,1],[49,144,256],[25,49,81]]
Output: [[6,80,2],[42,120,192],[175,21,189]]
Input : [[256,169,9,225],[36,121,144,81],[9,121,9,36],[400,361,100,9]]
Output: [[384,13,135,15],[24,1573,108,54],[180,11,108,6],[380,209,10,90]]
Input : [[9,361,784,144,484],[121,441,625,49,25],[256,100,36,81,529],[49,4,64,324,16],[25,1,841,196,9]]
Output: [[171,19,700,4032,22],[11,210,525,7,550],[176,60,6,63,23],[140,112,1152,162,368],[5,29,29,14,126]]
You must print or return the final matrix.
Могу ли я вместо этого изменить матрицу ввода?Ответы:
R ,
301287277274222217195186178174 байтНичего особенно творческого, включая нулевую буферизацию периферийных элементов матрицы ввода, более ранняя версия, улучшенная позже Робином:
Попробуйте это онлайн
Используя последовательность чисел в качестве входных данных и, следовательно, удаляя вызов функции, Ник Кеннеди ранее управлял 186-байтовой версией алгоритма следующим образом (с Робином -10 байтов -10). ):
избегая определения (рекурсивной) функции, плюс другие приятные преимущества.
Попробуйте это онлайн
источник
Рубин ,
140135 байтовПринимает плоский список в качестве входных данных, выводит плоский список.
Попробуйте онлайн!
Объяснение:
источник
Python 2 , 188 байт
Попробуйте онлайн!
Полная программа. Принимает ввод и печатает как плоский список.
источник
Perl 6 , 236 байт
Попробуйте онлайн!
источник
MATL ,
4948 байтовПопробуйте онлайн! Или проверьте все тестовые случаи .
Как это устроено
источник
JavaScript (ES6),
271259250245 байтСпасибо Луису Фелипе Де Иисусу Муньосу за −14 байтов!
Объяснение:
источник
C # (интерактивный компилятор Visual C #) , 220 байт
Попробуйте онлайн!
источник
Wolfram Language (Mathematica) , 224 байта
Попробуйте онлайн!
источник
JavaScript (Node.js) , 157 байт
Попробуйте онлайн!
-14 байт, спасибо @Arnauld, который также написал хороший тестовый комплект :)
Анонимная функция, которая принимает одномерный массив в качестве входных данных и параметр длины, указывающий число в столбцах / строках.
Каррированный вход указан как
f(array)(length)
.источник
Java 8,
299297 байтИзменяет матрицу ввода вместо возврата новой, чтобы сохранить байты.
Попробуйте онлайн.
Объяснение:
источник
Желе ,
7067 байтПопробуйте онлайн!
Я уверен, что это можно сделать гораздо более кратко, но я нашел это сложнее, чем казалось на первый взгляд. Объяснение, чтобы следовать, как только я попытался сыграть в гольф лучше.
Полная программа, которая принимает список целых чисел, соответствующих квадратной матрице, и возвращает список целых чисел, представляющих окончательную разобранную матрицу.
источник