Objetivo
Tengo una bonita foto que quiero colgar en mi pared. Y quiero que cuelgue allí de una manera espectacular, así que decidí colgarlo en las n
uñas donde n
hay un número entero positivo.
Pero también soy indeciso, así que si cambio de opinión, no quiero tener muchos problemas para sacar la foto. Por lo tanto, quitar cualquiera de las n
uñas debería hacer que la imagen se caiga. ¿Mencioné que no hay fricción en mi casa?
¿Me puedes ayudar?
Reglas
- Su programa debe leer el número
n
de stdin e imprimir en stdout (o los equivalentes de su idioma). - La salida debe ser la solución de acuerdo con la especificación de salida sin ningún otro carácter final o inicial. Sin embargo, los espacios en blanco finales y / o las nuevas líneas son aceptables.
- Debes usar exactamente las
n
uñas. - Suponiendo un mundo sin fricción, su solución debe cumplir las siguientes condiciones:
- Colgando la imagen como se describe en su solución, la imagen no debe caerse.
- Si se quita alguna de las uñas, la imagen debe caerse.
- Se aplican lagunas estándar. En particular, no puede realizar solicitudes, por ejemplo, al programa de verificación de soluciones de fuerza bruta.
Tenga en cuenta que 4.2 ya implica que todas las n
uñas deben estar involucradas.
Especificación de salida
- Todas las uñas se nombran de izquierda a derecha con la posición en la que se encuentran, comenzando en
1
. - Hay dos formas fundamentales de colocar la cuerda alrededor de un clavo: en sentido horario y en sentido antihorario. Denotamos un paso en sentido horario con
>
y un paso en sentido antihorario con<
. - Cada vez que la cuerda se coloca alrededor de una uña, sale por encima de las uñas, por lo que saltar uñas significa que la cuerda pasará por la parte superior de las uñas intermedias.
- Cada solución debe comenzar en la uña
1
y terminar en la uñan
. - La salida debe consistir en una secuencia de pasos en los que un paso es una combinación del nombre del clavo y la dirección en la que se coloca la cuerda alrededor.
Salida de ejemplo
Aquí hay un ejemplo de salida para n=5
y n=3
:
1>4<3<2>4>5< # n=5, incorrect solution
1>2<1<2>3<2<1>2>1<3> # n=3, correct solution
Y aquí hay una representación visual de la solución incorrecta para n=5
(awsumz gimp skillz)
La solución correcta para n=1
es simplemente 1>
o 1<
. Para múltiples uñas, puede haber diferentes soluciones. Solo debe generar uno ya que esto es parte de su puntaje.
Verificación
Puede verificar si una solución es correcta aquí: www.airblader.de/verify.php .
Utiliza una solicitud GET, por lo que puede llamarla directamente si lo desea. Por ejemplo, si foo
es un archivo que contiene una solución en cada línea, puede usar
cat foo | while read line; do echo `wget -qO- "www.airblader.de/verify.php?solution=$line" | grep "Passed" | wc -l`; done
Si cree que una solución es correcta pero el verificador la marca como incorrecta, ¡hágamelo saber!
Editar: y si su salida es tan larga que una solicitud GET no la cortará, hágamelo saber y haré una versión de solicitud POST. :)
Puntuación
Este es el código de golf. El puntaje es el número de bytes de su código fuente en la codificación UTF-8, por ejemplo, use esta herramienta . Sin embargo, hay una bonificación potencial por cada presentación:
Ejecute su programa para todos n
en el rango [1..20]
y agregue la longitud de todas las salidas para determinar su puntaje de salida . Reste su puntaje de salida 6291370
para obtener la cantidad de puntos de bonificación que puede deducir de su conteo de bytes para obtener su puntaje general . No hay penalización si su puntaje de salida es más alto que este número.
La presentación con el puntaje general más bajo gana. En el caso improbable de un empate, los desempates están en este orden: puntos de bonificación más altos, menor recuento de bytes, fecha de presentación anterior.
Publique las partes individuales (recuento de bytes, puntos de bonificación) del puntaje y el puntaje final, por ejemplo, " LOLCODE (44 - 5 = 39)
".
1>
se dibuja en la imagen). Y no hay n
donde no hay solución posible. Una solución válida para n=2
es 1>2<1<2>
.