Given a set of words without duplicates, find all word squares you can build from them.
A sequence of words forms a valid word square if the kth row and column read the exact same string, where 0 ≤ k < max(numRows, numColumns).
For example, the word sequence [“ball”,”area”,”lead”,”lady”] forms a word square because each word reads the same both horizontally and vertically.
1 | b a l l |
Note
- There are at least 1 and at most 1000 words.
- All words will have the exact same length.
- Word length is at least 1 and at most 5.
- Each word contains only lowercase English alphabet a-z.
Example
No.1
Input:
[“area”,”lead”,”wall”,”lady”,”ball”]
Output:
[[“wall”,”area”,”lead”,”lady”],[“ball”,”area”,”lead”,”lady”]]
Explanation:
The output consists of two word squares. The order of output does not matter (just the order of words in each word square matters).
No.2
Input:
[“abat”,”baba”,”atan”,”atal”]
Output:
[[“baba”,”abat”,”baba”,”atan”],[“baba”,”abat”,”baba”,”atal”]]
Code
1 | public class TrieNode { |