Antecedentes
La mayoría de los editores de texto (medio decentes) le permiten navegar por el texto con las teclas de flecha. Arriba y abajo le permiten navegar por las líneas, mientras que izquierda y derecha se mueven a través de una línea, pero también se envuelven. Además, si la línea es más corta que la posición X de su cursor, el cursor aparece al final de la línea pero vuelve a la misma posición X si continúa moviéndose hacia arriba o hacia abajo. Quizás la siguiente explicación visual ayudará:
Ejemplos de movimiento
Una muestra simple de texto podría verse así. El cursor se insertará entre dos caracteres en este texto, o al final.
-----
---
------
let's put the cursor here:
X-----
---
------
move down (v):
-----
X---
------
move left (<):
-----X
---
------
v
-----
---X
------
v (notice how the X position of the cursor has been maintained)
-----
---
-----X-
^
-----
---X
------
> (more line wrapping)
-----
---
X------
<
-----
---X
------
^ (the X-position from earlier is no longer maintained due to the left-right motion)
---X--
---
------
El reto
Dadas varias líneas de prueba ASCII, encuentre la ruta más corta desde la ubicación inicial hasta la ubicación final. La ubicación inicial está representada por ^
y la ubicación final está representada por $
, y solo habrá una de cada una. No se consideran parte del texto y no contribuyen a la "longitud" de esa línea.
La entrada consistirá en varias líneas de texto no en blanco. La salida será una serie de ^v<>
caracteres que muestran una de las rutas más cortas. Opcionalmente, puede asumir una nueva línea adicional al final de cada una, pero eso no se incluye como parte del texto navegable.
Puede escribir un programa o una función con nombre. El ganador será el envío más corto, medido en bytes.
Ejemplo de E / S
^Squares
are
fun$ny
vv<v (which is better than the naive vv>>>)
Squares
^are
funny$
<vv
Alp$habet^
Song
v<^
Mary had a little lamb,
His fleece was white as snow,
And$ everywhere that ^Mary went,
The lamb was sure to go.
^^>>>>v>>>
$^degenerate case
(no output)
v<vv
, ¿verdad? ¿O terminaría eso después del último personaje en esa línea?Respuestas:
CJam, 139 bytes
Bueno, esto tomó muchas horas para llegar a algo que se siente hecho. Parece que el tiempo que se tarda en optimizar agresivamente el código CJam es algo mayor que O (n) con respecto al tamaño del código ...
Puede probarlo en línea , pero para cualquier entrada para la que la mejor ruta sea al menos 6 operaciones más o menos, probablemente debería probarlo fuera de línea con un intérprete más rápido.
Aplastado:
Ampliado y comentado:
En general, esta es una solución bastante sencilla. "Ejecuta" los dígitos de la representación de base 5 de un número de ruta que se incrementa en cada iteración, comenzando con 0, hasta que una ruta funciona. Los dígitos
1
: se4
asignan a las operaciones arriba, abajo, izquierda y derecha, y0
no hace nada. La primera iteración usando una ruta de solo0
captura el caso degenerado. Todas las demás rutas que contienen a0
nunca se seleccionan porque son solo versiones de rutas ya probadas con no-ops adicionales.El estado se modela de la manera más minimalista posible: el texto con los marcadores de inicio y fin eliminados, la posición del cursor en el texto y la "memoria de columna". Las líneas nuevas se tratan principalmente como cualquier otro carácter, por lo que no hay un concepto de fila y la posición del cursor es solo un índice. Esto hace que moverse a la izquierda y a la derecha sea simple, que solo se implementan como decremento e incremento (con sujeción al tamaño del texto). Moverse hacia arriba y hacia abajo es un poco más complicado, pero aún manejable.
La reutilización del código fue una táctica de optimización bastante vital. Ejemplos de esto incluyen:
5
operación ficticia al inicio de la cadena de ruta, que también utiliza la0
lógica no operativa debido a la indexación de matriz circular y solo hay 5 operaciones definidas.En general, estoy muy contento con cómo salió esto. Este es definitivamente el mayor trabajo que he puesto en una respuesta de código de golf hasta la fecha (¡por algo que cabe en un tweet !?). Sin embargo, el tiempo de ejecución es bastante abismal. Para empezar, CJam no es exactamente el lenguaje más rápido y este algoritmo tiene una complejidad de algo como O (m * 5 n ) , donde m es el tamaño de la entrada yn es el tamaño de la salida. ¡Qué bueno que la velocidad no cuenta!
fuente
Pitón 2: 446
Solución directa. Estoy realizando una búsqueda de amplitud.
t
itera sobre todos los caminos diferentes. Conviertot
en base5
, pero solo uso las entradas, que no son cero.1
está arriba,2
está abajo,3
está a la izquierda y4
está a la derecha.Mantengo la posición actual del cursor en 3 variables
x
,y
yz
.x
es la línea,y
la posición de la columna yz
la posición de la columna 'oculta', si sube o baja y la línea es demasiado corta. Muchos ifs deciden cómo cambia la variable durante un movimiento.El preprocesamiento es realmente largo, las primeras 4 líneas realizan solo esta tarea.
El largo caso de prueba lleva mucho tiempo. El algoritmo tiene una complejidad de O (N * 5 ^ N), donde N es la longitud de la solución más corta.
Uso: ingrese las líneas como una sola cadena (líneas separadas por
\n
) como"Alp$habet^\nSong"
fuente
CJam - 274
¿Sin respuesta aún? Ok, aquí hay uno :)
Pruébelo en http://cjam.aditsu.net/ ... excepto por el ejemplo de Mary o algo de ese tamaño, probablemente querrá el intérprete de Java .
fuente