zoukankan      html  css  js  c++  java
  • Leetcode720.Longest Word in Dictionary词典中最长的单词

    给出一个字符串数组words组成的一本英语词典。从中找出最长的一个单词,该单词是由words词典中其他单词逐步添加一个字母组成。若其中有多个可行的答案,则返回答案中字典序最小的单词。

    若无答案,则返回空字符串。

    示例 1:

    输入: words = ["w","wo","wor","worl", "world"] 输出: "world" 解释: 单词"world"可由"w", "wo", "wor", 和 "worl"添加一个字母组成。

    示例 2:

    输入: words = ["a", "banana", "app", "appl", "ap", "apply", "apple"] 输出: "apple" 解释: "apply"和"apple"都能由词典中的单词组成。但是"apple"得字典序小于"apply"。

    注意:

    • 所有输入的字符串都只包含小写字母。
    • words数组长度范围为[1,1000]。
    • words[i]的长度范围为[1,30]。

    bool cmp1(string a, string b)
    {
        return a.size() > b.size();
    }
    
    bool cmp2(string a, string b)
    {
        return a < b;
    }
    
    class Solution {
    public:
        string longestWord(vector<string>& words) {
            int len = words.size();
            if(len <= 1)
                return len == 0? "":words[0];
            vector<string> res;
            map<string, int> check;
            for(int i = 0; i < len; i++)
            {
                check[words[i]] = 1;
            }
            sort(words.begin(), words.end(), cmp1);
            int MAXsize = 0;
            for(int i = 0; i < len; i++)
            {
                int size = words[i].size();
                bool flag = true;
                if(MAXsize != 0 && MAXsize > size)
                    continue;
                for(int j = 0; j < size - 1; j++)
                {
                    string temp = "";
                    for(int k = 0; k <= j; k++)
                    {
                        temp += words[i][k];
                    }
                    if(check[temp] != 1)
                    {
                        flag = false;
                        break;
                    }
                }
                if(flag == true)
                {
                    MAXsize = max(MAXsize, size);
                    res.push_back(words[i]);
                }
            }
            if(res.size() == 0)
                return "";
            sort(res.begin(), res.end(), cmp2);
            return res[0];
        }
    };
  • 相关阅读:
    spring属性注入
    spring的bean标签属性
    spring三种实例化bean的方式
    测试环境部署
    sql server将字符串转换为 uniqueidentifier 时失败
    mybatis parametertype 多个参数
    ORACLE-023:令人烦恼的 ora-01722 无效数字
    PostMan使用教程
    sqlserver复制表数据到另一个表
    to_number()函数的用法
  • 原文地址:https://www.cnblogs.com/lMonster81/p/10433990.html
Copyright © 2011-2022 走看看