Итерация Мура

9

Информация

Числа от 1 до 9 представляют ячейку в районе Мура , где 5 - центральная ячейка. Так:

123
456
789

1={-1,-1} 2={-1, 0} 3={-1, 1}
4={ 0,-1} 5={ 0, 0} 6={ 0, 1} 
7={ 1,-1} 8={ 1, 0} 9={ 1, 1}

Соревнование

Вы можете получить ввод через STDIN, ARGV или аргумент функции и либо вернуть результат, либо распечатать его в STDOUT. Входными данными является сетка N x N (топология тора, то есть если x или y <1, то x или y = N, а если x или y> N, то x или y = 1), и ваша программа должна вывести одно целое число сетки, заменяя каждую ячейку значением в ячейке Соседства Мура.

Пример входной сетки (2 x 2):

13
79

Вывод:

97
31

Объяснение:

Начиная с позиции 1,1 у нас есть значение 1, так как значение 1 = {- 1, -1}, мы должны получить 1 + (- 1), 1 + (- 1) = 0,0. И поскольку это тор 0,0, мы оборачиваемся вокруг N. Таким образом, мы получаем значение ячейки в позиции 1,1 (1) со значением ячейки в позиции 2,2 (9).

Для следующей ячейки 1,2 мы имеем значение 3 (= -1, 1), поэтому 1 + (- 1), 2 + (1) = 0,3. Оборачивается на 2,1, что является значением 7.

Значение следующей ячейки в 2,1 равно 7 (= 1, -1), поэтому 2+ (1), 1 + (- 1) = 3,0. Оборачивается до 1,2, что является значением 3.

Значение следующей ячейки в 2,2 равно 9 (= 1, 1), поэтому 2+ (1), 2 + (1) = 3,3. Оборачивается на 1,1, что является значением 1.

Больше примеров

Сетка ввода (3 х 3):

123
456
789

Ожидаемый результат:

987
654
321

Входная сетка (5 х 5):

77497
81982
32236
96336
67811

Ожидаемый результат:

28728
37337
11923
73369
77433

Заключительные заметки

Если у вас есть какие-либо вопросы, не стесняйтесь комментировать. Это соревнование по коду, самый короткий код выигрывает!

AndoDaan
источник
Как вы определяете положение элемента? Я не понимаю, как входной набор ячеек индексируется.
Rainbolt
@Rainbolt Входные данные индексируются строками, а затем столбцами. Таким образом, в последнем примере (входной) значение ячейки 2,3 равно 9. строка 2 = 81982, а третий столбец этого числа равен 9.
AndoDaan
1
связанные: codegolf.stackexchange.com/q/36839/15599
Уровень Река Сент-
4
Не мог не прочитать «Примеры Мура».
Томсминг

Ответы:

9

APL (33)

APL был сделан для этого. Это функция, которая принимает входную сетку в качестве матрицы N-N и возвращает выходную сетку в качестве матрицы N-N.

{(⍳⍴⍵)⌷¨(,∆∘.⊖(∆←2-⌽⍳3)∘.⌽⊂⍵)[⍵]}

Тестовое задание:

      ⍝ define input matrices
      ∆1 ← ↑(1 3)(7 9)
      ∆2 ← ↑(1 2 3)(4 5 6)(7 8 9)
      ∆3 ← ↑(7 7 4 9 7)(8 1 9 8 2)(3 2 2 3 6)(9 6 3 3 6)(6 7 8 1 1)
      ⍝ show input matrices
      ∆1 ∆2 ∆3
 1 3  1 2 3  7 7 4 9 7 
 7 9  4 5 6  8 1 9 8 2 
      7 8 9  3 2 2 3 6 
             9 6 3 3 6 
             6 7 8 1 1 
      ⍝ apply function to input matrices giving output matrices
      {(⍳⍴⍵)⌷¨(,∆∘.⊖(∆←2-⌽⍳3)∘.⌽⊂⍵)[⍵]} ¨ ∆1 ∆2 ∆3
 9 7  9 8 7  2 8 7 2 8 
 3 1  6 5 4  3 7 3 3 7 
      3 2 1  1 1 9 2 3 
             7 3 3 6 9 
             7 7 4 3 3 
Мэринус
источник
5

Питон, 174

def t(b):b=b.split("\n");E=enumerate;C=[-1]*3+[0]*3+[1]*3+[-1,0,1]*3;print"\n".join("".join(b[(i+C[int(x)-1])%len(b)][(j+C[int(x)+8])%len(y)]for j,x in E(y))for i,y in E(b))

Python не был создан для этого ... APL был!

Будет
источник
3

Python, 105

Принимает и возвращает список списков:

def f(a):e=enumerate;n=len(a);return[[a[(y+(v-1)/3-1)%n][(x+(v-1)%3-1)%n]for x,v in e(u)]for y,u in e(a)]

Принимает и возвращает строку (148 символов):

def f(s):
 a=[map(int,l)for l in s.split()];n=len(a);e=enumerate
 for y,u in e(a):print''.join(`a[(y+(v-1)/3-1)%n][(x+(v-1)%3-1)%n]`for x,v in e(u))
GRC
источник
2

MATLAB - 121 байт

function O=X(I),m=size(I,1);n=3*m;o=-1:1;c=o<2;M=c'*o+n*o'*c;D=repmat(I,3);C=D;C(:)=1:n*n;t=m+(1:m);O=C+M(D);O=D(O(t,t));

MATLAB был немного меньше для этого, чем APL, но немного больше для этого, чем Python. ;)

Тестовый вывод

X( [1 2 3; 4 5 6; 7 8 9] )

ans =

     9     8     7
     6     5     4
     3     2     1

X( [7 7 4 9 7; 8 1 9 8 2; 3 2 2 3 6; 9 6 3 3 6; 6 7 8 1 1] )

ans =

     2     8     7     2     8
     3     7     3     3     7
     1     1     9     2     3
     7     3     3     6     9
     7     7     4     3     3
COTO
источник