Выровнять текст по блоку

10

задача

Ваша задача - написать целую программу, которая выровняет входные данные в блоке заданного размера.

Входные данные:

40
Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor incididunt ut labore et dolore magna 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
adipiscing  elit,  sed do eiusmod tempor
incididunt  ut  labore  et  dolore magna
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.
                <-- note the linebreak

Детали ввода

  • Вы должны написать целую исполняемую / интерпретируемую программу.
  • Вы можете предположить, что ввод содержит только печатные символы ASCII и не содержит табуляции \t.
  • Входные данные могут содержать разрывы строк. Если это так, то они приведены в качестве \n, \rили в \r\nзависимости от того, что вы ожидаете. Они, однако, объединены на протяжении всего ввода.
  • Входные данные могут быть заданы в STDIN или в качестве аргументов командной строки. Вы можете использовать оба из них, если это соответствует вашим потребностям (например, прочитать размер блока из командных аргументов и ввести как stdin). Вы не можете, однако, жестко закодировать любую часть ввода в вашу программу.
  • Вы можете предположить, что размер блока указан как действительное положительное > 0число ( ).
  • Разрыв строки на входе обрабатывается так же, как и пробел (таким образом, является разделителем слов)
  • Если вход содержит несколько параллельных пробелов, они рассматриваются как одно.

Детали вывода

  • Вывод должен быть отформатирован в блок заданного размера. Форматирование выполняется путем добавления пробелов между словами.
  • Количество пробелов между словами в строке должно быть одинаковым для этой строки. Если это невозможно, необходимо добавить дополнительные пробелы один за другим после слов, начинающихся слева.
  • Если слово длиннее указанного размера блока, оно будет стоять на одной строке (и будет превышать размер блока).
  • Если вывод должен содержать только одно слово, он будет выровнен по левому краю.
  • Последняя строка вывода должна быть выровнена по левому краю, с одним пробелом между словами. Последняя строка выходных данных должна заканчиваться разрывом завершающей строки.

Ответ с самым коротким числом байтов через некоторое время выигрывает.
Если вам нужна дополнительная информация, оставьте комментарий.

Контрольные примеры

Input:
10
Lorem ipsum dolor sit amet,
consectetur adipiscing elit, sed do eiusmod tempor

Output:
Lorem
ipsum
dolor  sit
amet,
consectetur
adipiscing
elit,  sed
do eiusmod
tempor

Input:
20
Lorem     ipsum

dolor  sit amet,

Output:
Lorem   ipsum  dolor
sit amet,

Input:
1
Lorem ipsum dolor sit amet

Output:
Lorem
ipsum
dolor
sit
amet
Zereges
источник
Связанные с. (Наконец, второй вызов для моего типографского тега, который уже был автоматически удален.;))
Мартин Эндер
@ MartinBüttner Я не знал, что такой тег существует.
Зерегес
@ Vɪʜᴀɴ Вы должны написать целую исполняемую / интерпретируемую программу.
Деннис
@ppperry Интересно, почему-то он избежал моих навыков поиска
Zereges

Ответы:

1

Рубин, 179 символов

n=gets.to_i
s=t=''
$<.read.split.map{|w|if(t+w).size>=n
0while t.size<n&&(1..n).any?{|i|t.sub!(/[^ ]#{' '*i}(?=[^ ])/){|x|x+' '}}
s+=t+?\n
t=w
else
t+=' '+w
t.strip!
end}
puts s,t

Слишком долго ...

Полуголая версия:

n = gets.to_i
s = t = ''
$<.read.split.map{|w|
    if (t + w).size >= n
        0 while t.size < n && (1..n).any?{|i|t.sub!(/[^ ]#{' '*i}(?=[^ ])/){|x|x+' '}}
        s += t + ?\n
        t = w
    else
        t += ' ' + w
        t.strip!  # this is only necessary because of the very first word >:(
    end
}
puts s,t
Дверная ручка
источник
0

CJam, 87 байт

l~:LS*qNSerS%{(2$1$a+_S*,L>{;a\}{\;@;\}?}h;S*a]1>{I1>{LIs,-I,(md1b\aI,(*.+Sf*I.\}I?N}fI

Это все еще должно быть пригодным для игры в гольф. Попробуйте онлайн в интерпретаторе CJam .

Деннис
источник
0

Сетчатка , 133 байта

\s+

+`((1)*1 )((?<-2>.)*\S|\S+) 
:$3<LF>$1
m+`^(?=.(.)+$[^<TB>]*^(?>(?<-1>1)+)1)((.*):(\S+ +)|(\S+ +)(.*):)
$3$4$5 :$6
+`:|<LF>1+| (?= .*$)
<empty>

<empty>Представляет собой пустую косую линию. Для запуска кода поместите каждую строку в отдельный файл, замените <LF>символы перевода строки (0x0A) и <TB>табуляцию (0x09). Я добавлю объяснение, когда я закончу играть в гольф.

Мартин Эндер
источник