Word Search Helper

12

He estado haciendo búsquedas de palabras hace poco, y pensé que sería así mucho más fácil si todas las palabras se leen de izquierda a derecha. ¡Pero reescribir todas las líneas requiere mucho esfuerzo! Así que estoy reclutando golfistas de código para ayudar.

(Descargo de responsabilidad: la historia anterior puede ser remotamente precisa o no).

Su código tomará una cuadrícula rectangular y generará todas las líneas a través de ella en ambas direcciones.

La salida debe contener las 8 rotaciones de la cuadrícula (cardinales y diagonales principales), 'leer' de arriba a abajo, de izquierda a derecha. (Esto significa que cada "fila" se duplicará, una vez hacia adelante y otra hacia atrás).

Las divisiones de línea pueden ser un espacio o un salto de línea. Si elige espacios, las divisiones de rotación de la cuadrícula deben ser saltos de línea; de lo contrario, las divisiones de rotación de la cuadrícula deben ser dos saltos de línea.

Entrada de ejemplo (tomada como una matriz de caracteres, cadena multilínea u otro formato razonable)

ABCDE
FGHIJ
KLMNO
PQRST

Ejemplo de salida (usando la primera opción para divisiones)

ABCDE FGHIJ KLMNO PQRST
E DJ CIO BHNT AGMS FLR KQ P
EJOT DINS CHMR BGLQ AFKP
T OS JNR EIMQ DHLP CGK BF A
TSRQP ONMLK JIHGF EDBCA
P QK RLF SMGA TNHB OIC JD E
PKFA QLGB RMHC SNID TOJE
A FB KGC PLHD QMIE RNJ SO T

El orden de las rotaciones "leídas" no importa siempre y cuando los ocho cardenales e intercardinales primarios se realicen una vez.

Este es el , por lo que gana el código más corto. Se aplican lagunas estándar.

Deusovi
fuente
¿La cuadrícula solo contiene letras mayúsculas o puede ser el ASCII imprimible completo?
Denker
Casi duplicado (sin las diagonales) codegolf.stackexchange.com/questions/37940/word-search-puzzle
Digital Trauma
@DigitalTrauma: No, en realidad no, este no te pide que encuentres ninguna palabra.
Deusovi

Respuestas:

4

Python 3, 181 bytes

def f(s):
 for k in [1,0]*4:
  b=list(zip(*[([' ']*(len(s)-1-n)*k+list(i)+[' ']*n*k)[::-1] for n,i in enumerate(s)]))
  print([' '.join(i).replace(' ','') for i in b])
  if k==0:s=b

Explicación

def f(s):
 for k in [0]*4:                  # loop 4 times, we don't need the index so [0]*4 is shorter than range(4)
  l=len(s)-1                      # number of line

  # rotation of 45°
  a=[(['.']*(l-n)+list(i)+['.']*n)[::-1] for n,i in enumerate(s)]
  # tranform matrice :
  #  ABC      ..ABC      CBA..
  #  DEF  --> .DEF.  --> .FED.
  #  GHI      GHI..      ..IHG
  b=list(zip(*a))                 # transpose 
  #  CBA..      C..
  #  .FED.  --> BF.
  #  ..IHG      AEI
  #             .DH
  #             ..G
  print(' '.join(''.join(i).replace('.','') for i in b))

  # rotation of 90°
  a=[(list(i))[::-1] for n,i in enumerate(s)]
  # tranform matrice :
  #  ABC      CBA
  #  DEF  --> FED
  #  GHI      IHG
  b=list(zip(*a))                 # transpose 
  #  CBA       CFI
  #  FED   --> BEH
  #  IHG       ADG
  print(' '.join(''.join(i) for i in b))
  s=b

Resultados

>>> f(['ABCDE','FGHIJ','KLMNO','PQRST'])
['E', 'DJ', 'CIO', 'BHNT', 'AGMS', 'FLR', 'KQ', 'P']
['EJOT', 'DINS', 'CHMR', 'BGLQ', 'AFKP']
['T', 'OS', 'JNR', 'EIMQ', 'DHLP', 'CGK', 'BF', 'A']
['TSRQP', 'ONMLK', 'JIHGF', 'EDCBA']
['P', 'QK', 'RLF', 'SMGA', 'TNHB', 'OIC', 'JD', 'E']
['PKFA', 'QLGB', 'RMHC', 'SNID', 'TOJE']
['A', 'FB', 'KGC', 'PLHD', 'QMIE', 'RNJ', 'SO', 'T']
['ABCDE', 'FGHIJ', 'KLMNO', 'PQRST']

>>> f(['ABCDEF','GHIJKL','MNOPQR','STUVWX'])
['F', 'EL', 'DKR', 'CJQX', 'BIPW', 'AHOV', 'GNU', 'MT', 'S']
['FLRX', 'EKQW', 'DJPV', 'CIOU', 'BHNT', 'AGMS']
['X', 'RW', 'LQV', 'FKPU', 'EJOT', 'DINS', 'CHM', 'BG', 'A']
['XWVUTS', 'RQPONM', 'LKJIHG', 'FEDCBA']
['S', 'TM', 'UNG', 'VOHA', 'WPIB', 'XQJC', 'RKD', 'LE', 'F']
['SMGA', 'TNHB', 'UOIC', 'VPJD', 'WQKE', 'XRLF']
['A', 'GB', 'MHC', 'SNID', 'TOJE', 'UPKF', 'VQL', 'WR', 'X']
['ABCDEF', 'GHIJKL', 'MNOPQR', 'STUVWX']

con una salida más limpia (189 bytes)

j=' '.join
def f(s):
 for k in [1,0]*4:
  b=list(zip(*[([' ']*(len(s)-1-n)*k+list(i)+[' ']*n*k)[::-1] for n,i in enumerate(s)]))
  print(j(j(i).replace(' ','') for i in b))
  if k==0:s=b

.

>>> f(['ABCDE','FGHIJ','KLMNO','PQRST'])
E DJ CIO BHNT AGMS FLR KQ P
EJOT DINS CHMR BGLQ AFKP
T OS JNR EIMQ DHLP CGK BF A
TSRQP ONMLK JIHGF EDCBA
P QK RLF SMGA TNHB OIC JD E
PKFA QLGB RMHC SNID TOJE
A FB KGC PLHD QMIE RNJ SO T
ABCDE FGHIJ KLMNO PQRST
Erwan
fuente
¿Cómo se transforma una matriz? (bloque de código 2)
CalculatorFeline
@CatsAreFluffy Agregué un paso más en las explicaciones
Erwan
Estoy bastante seguro de que tranforme no es una palabra. (transformar?)
CalculatorFeline
@CatsAreFluffy ^^ ok, creo que era obvio que el inglés no es mi lengua materna
Erwan
Muy buena respuesta!
Timtech
1

MATL , 40 bytes

t!tP!tP!GXKZyqXI"IZ}w_w2$:"K@2$Xd!]K!XKx

La entrada es una matriz de caracteres 2D en notación Matlab:

['ABCDE'; 'FGHIJ'; 'KLMNO'; 'PQRST']

La salida contiene cada "palabra" en una línea separada.

Pruébalo en línea!

t          % input 2D char array. Duplicate. The original copy will produce
           % the words left to right when displayed
!          % transpose. This will produce the words up to down
tP!        % duplicate, flip upside down, transpose. This will produce the
           % words right to left
tP!        % Same. This will produce the words down to up 
GXK        % push input again. Copy to clipboard K
Zy         % get size (length-2 vector; [4 5] in the example)
q          % decrement by 1 (gives  [3 4] in the example)
XI         % copy to clipboard I
"          % loop: do this twice, consuming the decremented length-2 vector
  I        %   push decremented size vector again
  Z}       %   split into its two elements (pushes 3 and 4 in the example)
  w_w      %   swap, negave, swap (results in -3, 4 in the example)
  2$:      %   binary range: indices of diagonals  ([-3 -2 -1 0 1 2 3 4]
           %   in the first iteration in the example, [-4 -3 -2 -1 0 1 2 3]
           %   in the second)
  "        %   for each
    K      %     push input (first iteration) or its tranposed version (second)
    @      %     push index of diagonal
    2$Xd!  %     extract that diagonal as a row vector
  ]        %   end for each
  K!XKx    %   update clipboard K with transposed version for next iteration
           % end loop. Display
Luis Mendo
fuente