forked from ngiengkianyew/daily-coding-problem
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathproblem_028.py
49 lines (43 loc) · 1.71 KB
/
problem_028.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
def justify_text(words, max_line_length):
lines = list()
cumulative_length = -1
current_words = list()
line_lengths = list()
for word in words:
if cumulative_length + (len(word) + 1) > max_line_length:
lines.append(current_words)
line_lengths.append(cumulative_length)
cumulative_length = -1
current_words = list()
cumulative_length += (len(word) + 1)
current_words.append(word)
# print(current_words)
# print(cumulative_length)
if current_words:
lines.append(current_words)
line_lengths.append(cumulative_length)
# print(lines)
# print(line_lengths)
justified_lines = list()
for words, length in zip(lines, line_lengths):
spaces_to_add = max_line_length - length
guaranteed_spaces = 1 + (spaces_to_add // (len(words) - 1))
bonus_space_recipients = spaces_to_add % (len(words) - 1)
# print("spaces_to_add: {}".format(spaces_to_add))
line = ""
for (index, word) in enumerate(words[:-1]):
line += word
line += guaranteed_spaces * " "
if index < bonus_space_recipients:
line += " "
line += words[-1]
# print(line)
justified_lines.append(line)
# print(justified_lines)
return justified_lines
assert justify_text(["the", "quick", "brown", "fox", "jumps",
"over", "the", "lazy", "dog"], 16) == \
['the quick brown', 'fox jumps over', 'the lazy dog']
assert justify_text(["the", "quick", "brown", "fox", "jumps", "over"], 16) == \
['the quick brown', 'fox jumps over']
assert justify_text(["the", "quick"], 16) == ['the quick']