Problem
You are given an array of words
where each word consists of lowercase English letters.
wordA
is a predecessor of wordB
if and only if we can insert exactly one letter anywhere in wordA
without changing the order of the other characters to make it equal to wordB
.
- For example,
"abc"
is a predecessor of"abac"
, while"cba"
is not a predecessor of"bcad"
.
A word chain is a sequence of words [word1, word2, ..., wordk]
with k >= 1
, where word1
is a predecessor of word2
, word2
is a predecessor of word3
, and so on. A single word is trivially a word chain with k == 1
.
Return the length of the longest possible word chain with words chosen from the given list of words
.
Examples
Example 1:
|
|
Example 2:
|
|
Example 3:
|
|
Solution
Method 1 - DP
- Sort the
words
by word’s length. (also can apply bucket sort) - For each word, generate all possible previous word
prev
with 1 letter missing. - If we have seen this previous word, update the longest chain for the current word.
- Finally return the longest word chain.
Here is the approach:
- Sorting: Sort the words by their lengths. This ensures that when we try to build the word chain, we only look at words with lengths less than the current word.
- Dynamic Programming: Use a hashmap to keep track of the longest chain ending at each word.
- Checking Predecessors: For each word, try to remove each character one by one to see if the resulting word exists in the hashmap, indicating a valid predecessor.
Code
|
|
|
|
Complexity
- ⏰ Time complexity:
O(n * m^2)
, wheren
is the number of words, andm
is the maximum length of a word. The sorting takesO(n log n)
. For each word, we potentially look atm
predecessor candidates, each takingO(m)
to check. - 🧺 Space complexity:
O(n)
, used by the hashmap to store the longest chain lengths of words.