Antecedentes
En la tipografía, los ríos son espacios visuales en un bloque de texto, que se producen debido a la alineación coincidente de los espacios. Estos son particularmente molestos ya que su cerebro parece captarlos más fácilmente en la visión periférica, lo que distrae constantemente sus ojos.
Como ejemplo, tome el siguiente bloque de texto, líneas discontinuas de modo que el ancho de la línea no exceda los 82 caracteres :
Lorem ipsum dolor sit amet, consectetur adipisicing elit, sed do eismod tempor
incididunt ut labore et dolore maga aliqua. Ut enim ad minim veniam, quis nostrud
exercitation ullamco laboris nisi ut aliquip ex ea commodo consequat. Duis aute
irure dolor in reprehenderit in voluptate velit esse cillum dolore eu fugiat nulla
pariatur. Excepteur sint occaecat cupidatat non proident, sunt in culpa qui
officia deserunt mollit anim id est laborum. Lorem ipsum dolor sit amet,
consectetur adipisicing elit, sed do eismod tempor incididunt ut labore et dolore
maga aliqua. Ut enim ad minim veniam, quis nostrud exercitation ullamco laboris
nisi ut aliquip ex ea commodo consequat. Duis aute irure dolor in reprehenderit in
voluptate velit esse cillum dolore eu fugiat nulla pariatur. Excepteur sint
occaecat cupidatat non proident, sunt in culpa qui officia deserunt mollit anim id
est laborum.
Hay un río que abarca seis líneas en la parte inferior derecha, que he resaltado en el siguiente bloque:
Lorem ipsum dolor sit amet, consectetur adipisicing elit, sed do eismod tempor
incididunt ut labore et dolore maga aliqua. Ut enim ad minim veniam, quis nostrud
exercitation ullamco laboris nisi ut aliquip ex ea commodo consequat. Duis aute
irure dolor in reprehenderit in voluptate velit esse cillum dolore eu fugiat nulla
pariatur. Excepteur sint occaecat cupidatat non proident, sunt in culpa qui
officia deserunt mollit anim id est laborum. Lorem█ipsum dolor sit amet,
consectetur adipisicing elit, sed do eismod tempor█incididunt ut labore et dolore
maga aliqua. Ut enim ad minim veniam, quis nostrud█exercitation ullamco laboris
nisi ut aliquip ex ea commodo consequat. Duis aute█irure dolor in reprehenderit in
voluptate velit esse cillum dolore eu fugiat nulla█pariatur. Excepteur sint
occaecat cupidatat non proident, sunt in culpa qui█officia deserunt mollit anim id
est laborum.
Podemos mitigar esto eligiendo un ancho de columna ligeramente diferente. Por ejemplo, si diseñamos el mismo texto usando líneas que no tengan más de 78 caracteres , no habrá un río con más de dos líneas:
Lorem ipsum dolor sit amet, consectetur adipisicing elit, sed do eismod tempor
incididunt ut labore et dolore maga aliqua. Ut enim ad minim veniam, quis
nostrud exercitation ullamco laboris nisi ut aliquip ex ea commodo consequat.
Duis aute irure dolor in reprehenderit in voluptate velit esse cillum dolore
eu fugiat nulla pariatur. Excepteur sint occaecat cupidatat non proident, sunt
in culpa qui officia deserunt mollit anim id est laborum. Lorem ipsum dolor
sit amet, consectetur adipisicing elit, sed do eismod tempor incididunt ut
labore et dolore maga aliqua. Ut enim ad minim veniam, quis nostrud
exercitation ullamco laboris nisi ut aliquip ex ea commodo consequat. Duis
aute irure dolor in reprehenderit in voluptate velit esse cillum dolore eu
fugiat nulla pariatur. Excepteur sint occaecat cupidatat non proident, sunt in
culpa qui officia deserunt mollit anim id est laborum.
Tenga en cuenta que para el propósito de esta pregunta solo estamos considerando fuentes monoespaciadas, de modo que los ríos son simplemente columnas verticales de espacios. La longitud de un río es la cantidad de líneas que abarca.
Aparte: si le interesa la detección de ríos en fuentes proporcionales, hay algunas publicaciones interesantes en la red.
El reto
Se le proporciona una cadena de caracteres ASCII imprimibles (punto de código 0x20 a 0x7E), es decir, una sola línea. Imprima este texto, con un ancho de línea entre 70 y 90 caracteres (inclusive), de modo que se minimice la longitud máxima de cualquier río en el texto. Si hay varios anchos de texto con la misma longitud de río máxima (mínima), elija el ancho más estrecho. El ejemplo anterior con 78 caracteres es la salida correcta para ese texto.
Para dividir líneas, debe reemplazar los caracteres de espacio (0x20) con saltos de línea, de modo que las líneas resultantes tengan tantos caracteres como sea posible, pero no más que el ancho de texto elegido. Tenga en cuenta que el salto de línea resultante en sí mismo no es parte de ese recuento. Como ejemplo, en el último bloque anterior, Lorem[...]tempor
contiene 78 caracteres, que también es el ancho del texto.
Puede suponer que la entrada no contendrá espacios consecutivos y no tendrá espacios iniciales o finales. También puede suponer que ninguna palabra (subcadena consecutiva de no espacios) contendrá más de 70 caracteres.
Puede escribir un programa o función, tomando datos a través de STDIN, argumento de línea de comando o argumento de función e imprimiendo el resultado en STDOUT.
Este es el código de golf, por lo que gana la respuesta más corta (en bytes).
fuente
Respuestas:
CJam, 116106
99 84 7772 bytesToma la entrada de una sola línea e imprime la salida correcta en STDOUT.
ACTUALIZACIÓN : mejoró mucho y eliminó los bucles redundantes al hacer todos los cálculos en el propio bucle de clasificación. También se corrigió un error en el cálculo de la longitud del río.
Explicación pronto (después de jugar golf aún más)
Pruébalo aquí
fuente
ea~
lugar deX
cada vez. Guarda dos bytes.Rubí
162 160 158 152 160157 ( de demostración )La versión sin golf:
fuente
%r{...}
me permite usar la interpolación de cadenas. Acabo de intentarlo21.times
, pero tiene algunas implicaciones más en el futuro, y no he logrado llegar a una solución más corta.APL (105)
Explicación:
(K⊂⍨' '=K←' ',⍵)
: Agregue un espacio delante⍵
y luego divida⍵
en los espacios. Cada palabra retiene el espacio con el que comienza.∘{
...}¨70+⍳21
: con ese valor, para cada número en el rango[71, 91]
: (Debido a la forma en que se dividen las palabras, cada 'línea' termina con un espacio adicional al principio, que se eliminará más adelante. El rango se desplaza por uno para compensar el espacio extra.)×⍴⍺:
: si todavía quedan palabras,z←⍵>+\≢¨⍺
: obtenga la longitud de cada palabra y calcule un total acumulado de la longitud, por palabra. Marque con1
todas las palabras que se pueden tomar para completar la siguiente línea y guárdeloz
.(⊂z/⍺),⍵∇⍨⍺⍨~z
: toma esas palabras y luego procesa lo que queda de la lista.⋄⍺
: si no, return⍺
(que ahora está vacío).G←
: almacena la lista de listas de líneas enG
(una para cada longitud de línea posible).V←{
...}¨G
: para cada posibilidad, calcule la longitud del río más largo y guárdelo enV
:+\↑≢¨¨⍵
: obtenga la longitud de cada palabra (nuevamente), y haga una matriz con las longitudes. Calcule el total acumulado de cada línea en las filas de la matriz. (Por lo tanto, se ignora el espacio adicional al comienzo de cada línea).2≠⌿
: para cada columna de la matriz, vea si la longitud actual de la línea en ese punto no coincide con la línea que sigue. Si es así, hay no un río allí.⊂⍨¨↓⍉
: divide cada columna de la matriz por sí misma (en la1
s). Esto proporciona una lista de listas, donde para cada río habrá una lista[1, 0, 0, ...]
, dependiendo de la longitud del río. Si no hay río, la lista estará[1]
.⌈/≢¨
: obtenga la longitud de cada río y obtenga el valor máximo de eso.⊃G/⍨V=⌊/V
: desdeG
, seleccione el primer elemento para el que la longitud del río más largo es igual al mínimo para todos los elementos.{1↓∊⍵,3⊃⎕TC}¨
: para cada línea, unir todas las palabras, eliminar el elemento de puño (el espacio extra desde el principio) y agregar una nueva línea al final.∊
: une todas las líneas juntas.fuente
Bash + Coreutils
236157 bytesEditado con un enfoque diferente, bastante más corto que antes:
Lee la cadena de entrada desde la línea de comando.
Con 3 clases anidadas, me estremezco al pensar cuál es la complejidad del tiempo Big-O para esto, pero completa el ejemplo en menos de 10 segundos en mi máquina.
fuente
Python, 314 bytes
Muchas gracias a SP3000, grc y FryAmTheEggman:
fuente
JavaScript (ES6) 194
202Solución iterativa, quizás más corta si se hace recursiva
Explicado
Prueba en la consola FireFox / FireBug.
Salida
fuente
Python 3, 329 bytes
Versión sin golf:
fuente