Skip to content

Latest commit

 

History

History
42 lines (37 loc) · 1.62 KB

Longest_Word_in_Dictionary.md

File metadata and controls

42 lines (37 loc) · 1.62 KB

720. Longest Word in Dictionary

Given a list of strings words representing an English Dictionary, find the longest word in words that can be built one character at a time by other words in words. If there is more than one possible answer, return the longest word with the smallest lexicographical order.

If there is no answer, return the empty string.

Example 1:

Input: 
words = ["w","wo","wor","worl", "world"]
Output: "world"
Explanation: 
The word "world" can be built one character at a time by "w", "wo", "wor", and "worl".

Example 2:

Input: 
words = ["a", "banana", "app", "appl", "ap", "apply", "apple"]
Output: "apple"
Explanation: 
Both "apply" and "apple" can be built from other words in the dictionary. However, "apple" is lexicographically smaller than "apply".

Code:

class Solution {
    public String longestWord(String[] words) {
        Arrays.sort(words);
        Set built = new HashSet();
        String res = "";
        for (String word : words) {
            if (word.length() == 1 || built.contains(word.substring(0, word.length() - 1))) {
                res = res.length() < word.length() ? word : res;
                built.add(word);
            }
        }
        return res;
    }
}

解题思路

  • 使用Arrays.sort()函数对字符串数组进行排序,所得到的新的字符串数组按照字母表以及字典顺序出现;
  • 使用HashSet辅助,存下字典的可建set;
  • 如果单词的长度增大,则更新返回单词。