MATL , 15 байт
X>ttq*QwoEqGd*+
Попробуйте онлайн!
Собрать и распечатать в виде матрицы
Как?
Изменить: та же техника, что и ответ @ Doorknob, только пришли по-другому.
Разница между диагональными элементами спирали заключается в арифметической последовательности . Сумма из слагаемых равна (по обычной формуле AP). Эта сумма, увеличенная на 1, дает диагональный элемент в позиции .n n ( n - 1 ) ( n , n )0,2,4,6,8,…nn(n−1)(n,n)
Учитывая , мы находим максимум этих двух, который является «слоем» спирали, к которой принадлежит эта точка. Затем мы находим диагональное значение этого слоя как . Для четных слоев значение в тогда равно , для нечетных слоев .v = n ( n - 1 ) + 1 ( x , y ) v + x - y v - x + y(x,y)v=n(n−1)+1(x,y)v+x−yv−x+y
X> % Get the maximum of the input coordinates, say n
ttq* % Duplicate that and multiply by n-1
Q % Add 1 to that. This is the diagonal value v at layer n
wo % Bring the original n on top and check if it's odd (1 or 0)
Eq % Change 1 or 0 to 1 or -1
Gd % Push input (x, y) again, get y - x
* % Multiply by 1 or -1
% For odd layers, no change. For even layers, y-x becomes x-y
+ % Add that to the diagonal value v
% Implicit output
Альтернативное 21-байтовое решение:
Pdt|Gs+ttqq*4/QJb^b*+
Попробуйте онлайн!
Соберите и распечатайте как матрицу.
Из вышесказанного мы знаем, что функция, которую мы хотим
f=m∗(m−1)+1+(−1)m∗(x−y)
где .m=max(x,y)
Некоторые базовые вычисления покажут, что одно выражение для максимум двух чисел
m=max(x,y)=x+y+abs(x−y)2
Подставляя одно в другое, мы находим, что одна альтернативная форма для :f
f=(x−y)⋅ik+14((k−2)⋅k)+1
где .k=abs(x−y)+x+y
Это функция, которую реализует решение.