• Leetcode 720. 词典中最长的单词(为啥感觉这道题很难?)


    在这里插入图片描述
    给出一个字符串数组 words 组成的一本英语词典。返回 words 中最长的一个单词,该单词是由 words 词典中其他单词逐步添加一个字母组成。

    若其中有多个可行的答案,则返回答案中字典序最小的单词。若无答案,则返回空字符串。

    示例 1:

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

    示例 2:

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

    提示:

    • 1 <= words.length <= 1000
    • 1 <= words[i].length <= 30
    • 所有输入的字符串 words[i] 都只包含小写字母。

    主要思路:先自定义排序,然后定义个二维数组用来存储长度一致的单词
    之后判断长度是否连续,内容是否递增即可
    Code:

    class Solution {
    public:
        static bool cmp(const string &s1,const string &s2)
        {
            if(s1.length()==s2.length())
                return s1<s2;
            
            return s1.length()<s2.length();
        }
        string longestWord(vector<string>& words) {
            sort(words.begin(),words.end(),cmp);
            int len=1;
            int maxlen=words[words.size()-1].length();
            vector<vector<string>>vec;
            
            int start_index=0;
            for(int i=1;i<=maxlen;i++)
            {
                bool flag=false;//用来判断长度是否是连续
                bool flag2=false;//用来判断内容是否递增
                vector<string>temp;
                for(int j=start_index;j<words.size();j++)
                {
                    
                    if(words[j].length()==i)
                    {
                        
                        flag=true;
                        //cout<<words[j]<<endl;
                        
                        if(i!=1)
                        {
                            vector<string>sub=vec[i-2];
                            string t=words[j].substr(0,i-1);
                            if(find(sub.begin(),sub.end(),t)!=sub.end())
                            {
                                //            cout<<words[j]<<endl;
                                temp.push_back(words[j]);
                                flag2=true;
                            }
                        }
                        if(i==1)
                        {
                            flag2=true;
                            temp.push_back(words[j]);
                        }
                        
                    }
                    else
                    {
                        start_index=j;
                        break;
                    }
                    
                }
                
                if(flag&&flag2)
                {
                    if(i==maxlen)
                        return temp[0];
                }
                if(!flag2 || !flag )
                {
                    
                    if(vec.size())
                    {
                        return vec[i-2][0];
                    }
                    else
                        return "";
                }
                else
                {
                    vec.push_back(temp);
                }
                
            }
            
            return "";
            
        }
    };
    
    
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26
    • 27
    • 28
    • 29
    • 30
    • 31
    • 32
    • 33
    • 34
    • 35
    • 36
    • 37
    • 38
    • 39
    • 40
    • 41
    • 42
    • 43
    • 44
    • 45
    • 46
    • 47
    • 48
    • 49
    • 50
    • 51
    • 52
    • 53
    • 54
    • 55
    • 56
    • 57
    • 58
    • 59
    • 60
    • 61
    • 62
    • 63
    • 64
    • 65
    • 66
    • 67
    • 68
    • 69
    • 70
    • 71
    • 72
    • 73
    • 74
    • 75
    • 76
    • 77
    • 78
    • 79
    • 80
    • 81
    • 82
    • 83
    • 84
  • 相关阅读:
    ECMAScript6 解构赋值
    技术策划学习 —— 引擎工具链高级概念与应用
    全球 PC 卖不动,Windows 下滑 12%……近 18 万亿市值的微软,全靠 OpenAI 撑着?
    MyBatis-Plus(3) 自定义逻辑删除插件 -- 全局处理xml中的SQL
    【人大金仓】迁移MySql数据库到人大金仓,出现sys_config表重复
    Selenium自动化测试-设置元素等待
    MySQL索引和优化
    Android修行手册-POI操作Excel文档
    clickhouse单节点以及集群的安装
    RabbitMQ 之 Work Queues 工作队列
  • 原文地址:https://blog.csdn.net/qq_45662588/article/details/125485772