Search⌘ K
AI Features

Solution: Before and After Puzzle

Understand how to apply hash maps for merging phrases into Before and After puzzles by matching and combining words. This lesson helps you implement an optimized solution, manage duplicates, and sort results, enhancing your coding interview problem-solving skills.

Statement

Given a list of strings phrases, generate all possible Before and After puzzles.

Each phrase is a string composed of lowercase English letters and spaces. No phrase begins or ends with a space, and no phrase contains consecutive spaces.

A Before and After puzzle is formed by merging two phrases such that the last word of the first phrase is identical to the first word of the second phrase. When merging, this shared word appears only once in the resulting combined phrase.

For every pair of indices i and j where i \neq j, consider forming a Before and After puzzle by using phrases[i] as the first phrase and phrases[j] as the second phrase. Since the order of the two phrases matters, both orderings of each pair should be considered.

Return a list of all distinct Before and After puzzles that can be formed, sorted in lexicographical order.

Note: Duplicate phrases may exist in the input. Pairs are determined by index, not by value, meaning two phrases at different indices can be paired even if they have the same content. However, duplicate results in the output should be removed.

Constraints:

  • 11 \leq phrases.length 100\leq 100

  • 11 \leq phrases[i].length 100\leq 100 ...