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 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:
phrases.length
phrases[i].length
The key idea is to use a hash map to efficiently match the last word of one phrase with the first word of another. We build a mapping from each phrase’s first word to the indices where that phrase appears. Then, for every phrase, we extract its last word and look it up in the hash map to find all candidate phrases that start with that same word. For each valid pair (where the two phrases are at different indices), we merge them by appending ...
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 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:
phrases.length
phrases[i].length
The key idea is to use a hash map to efficiently match the last word of one phrase with the first word of another. We build a mapping from each phrase’s first word to the indices where that phrase appears. Then, for every phrase, we extract its last word and look it up in the hash map to find all candidate phrases that start with that same word. For each valid pair (where the two phrases are at different indices), we merge them by appending ...