Escriba una función que tome dos parámetros: un entero positivo n y una lista de palabras.
Dado un cubo de n -by- n -by- n unidades, asigne una letra aleatoria (AZ) a cada unidad de superficie. (Para un cubo de 3x3x3, habría 9 unidades de superficie en cada cara).
Luego determine si es posible que una hormiga camine por la superficie (con la capacidad de cruzar caras) para deletrear cada una de las palabras proporcionadas. Suponga que para deletrear una palabra, las letras deben estar arriba / abajo o izquierda / derecha adyacentes, pero no necesariamente en la misma cara. [ Editar, para mayor claridad: la hormiga puede invertir su camino y usar letras más de una vez. Cada unidad de superficie cuenta como un carácter, por lo que para deletrear una palabra con letras repetidas (por ejemplo, "ver") la hormiga tendría que visitar tres unidades adyacentes.]
La función debería generar dos cosas:
1) Cada una de las letras en cada cara, de tal manera que se pueda inferir la topología. Por ejemplo, para un cubo de 2x2x2, un resultado aceptable se vería así:
QW
ER
TY OP UI
DF JK XC
AS
GH
LZ
VB
2) Cada una de las palabras, junto con un booleano que representa si es posible que la hormiga deletree la palabra caminando a lo largo de la superficie del cubo. Por ejemplo:
1 ask
0 practical
1 pure
0 full
Desafío de bonificación (no tendrá en cuenta el puntaje, solo por diversión): en lugar de que n represente solo el tamaño del cubo, que n también represente la dimensionalidad de la forma. Entonces, un n de 2 produciría un cuadrado de 2x2; un n de 3 produciría un cubo de 3x3x3; y un n de 4 produciría un tesseract de 4x4x4x4.
qwq
oqq
en el cubo de ejemplo?Respuestas:
Rubí, 272 bytes.
Se agregan dos líneas nuevas innecesarias al código a cada lado de la función anidada
g
para mejorar la legibilidad. Estos están excluidos de la puntuación. Los caracteresf=
que asignan la función anónima a una variable también están excluidos.El formato de salida es
0
o1
según la pregunta en lugar del nativo de Rubytrue
yfalse
. Se utiliza una nueva línea (en lugar de un espacio) para separar el booleano y la palabra. Tengo entendido que esta es una interpretación aceptable de los requisitos de salida, pero si no, el impacto en el recuento de bytes sería menor.Salida
Después de unas 50 llamadas como esta:
Finalmente obtuve el siguiente resultado con 2 hits.
ANT
está en la parte inferior derecha hacia arriba, yAN
es compartido porCAN
, con laC
ronda de ajuste hacia arriba a la izquierda.Explicación
El despliegue particular del cubo seleccionado fue elegido en parte por su facilidad de dibujo, pero principalmente por su facilidad de búsqueda.
Los caracteres que no son del alfabeto (los puntos más la nueva línea al final de cada línea) son una parte importante del campo donde se puede encontrar a la hormiga caminando.
La búsqueda se realiza mediante la función recursiva
g
, que está anidada en la funciónf
. Si la palabra pasada es una cadena vacía, la búsqueda está completa y$r
se establece en 1. Si la hormiga está en un cuadrado de letra que corresponde a la primera letra de la palabra, la búsqueda continúa en las cuatro direcciones: la función se llama nuevamente con la palabra acortada quitando su primera letra. En este caso, se ignora el parámetro de dirección. El movimiento se realiza mediante una llamada recursiva con el índice de la celda alterado por los valores enx.
El resultado de la adición se toma el módulo del tamaño de la cuadrícula más una media línea adicional. Esto significa que la línea inferior se ajusta a la parte superior y viceversa, con el desplazamiento horizontal correcto.Si la hormiga está en un cuadrado que no es letra, debe zigzaguear en un movimiento de escalera hasta que encuentre un cuadrado de letra. Ella zizag en dirección sureste o noroeste. Esto se simula mediante llamadas recursivas con el
d
parámetro XORed con 1 cada vez para realizar un seguimiento de su movimiento. Hasta que llegue al siguiente cuadro de letras, no se acortará la palabra de entrada. Convenientemente, esto puede hacerse por la misma recursión que se utiliza cuando buscamos en el área con letras. La diferencia es que la recursión tiene solo una rama cuando la hormiga está en el área de espacios en blanco, en lugar de 4 en el área de la letra.Código comentado
fuente