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];
        }
    };
  • 相关阅读:
    观察是快速成长的一个牛逼技能
    linux下使用lftp的小结(转)
    关于升级cocos2d-x网络库来支持ipv6、https,以及socket怎么支持ipv6
    cocos2dx支持arm64
    android studio 命令行编译cocos 3.15.1 安卓工程
    认识Android.mk和Application.mk
    mac os x下Android Studio3.0 配置本地 Gradle
    图片转成base64编码
    集成pbc
    6、SpringMVC:结果跳转方式 和 数据提交时的处理
  • 原文地址:https://www.cnblogs.com/lMonster81/p/10433991.html
Copyright © 2011-2022 走看看