Search⌘ K
AI Features

Solution: Text Justification

Explore how to apply a greedy algorithm to the text justification problem by arranging words into lines of specified width. Learn to distribute spaces evenly across lines, handle last line left-justification, and manage edge cases. Understand the step-by-step process and analyze the time and space complexity of the solution in JavaScript.

Statement

You are given an array of strings, words, and an integer, maxWidth. Your task is to reformat the text by arranging the words into lines of a specified width. Each line must have exactly maxWidth characters.

Words should be packed into lines using a greedy approach, which means you should fit as many words as possible onto each line before moving to the next. For this purpose, if the length of the words is less than the maxWidth, then add empty spaces ‘ ’ to adjust the length of each line.

The formatting rules are as follows:

  • For all lines except the last one, distribute extra spaces between words as evenly as possible to align both left and right.

  • If the spaces don’t divide evenly, the leftmost gaps should receive the extra spaces ‘ ’.

  • The last line of text and any line with only a single word must be left-justified. This means words are separated by a single space separates words, and the remaining width is filled with spaces on the right.

You can assume the following:

  • A word is defined as a character sequence consisting of non-space characters only.

  • Each word’s length is guaranteed to be greater than 0 and not exceed maxWidth.

  • The input array words contains at least one word.

Constraints:

  • 11 \leq words.length ...