Leetcode刷题-522最长特殊序列II

题目描述:

给定字符串列表 strs ,返回它们中最长的特殊序列 。如果最长特殊序列不存在,返回 -1 。
最长特殊序列定义:该序列为某字符串独有的最长子序列(即不能是其他字符串的子序列),s 的子序列可以通过删去字符串 s 中的某些字符实现。
来源:力扣(LeetCode)

示例1:

输入: strs = [“abc”,“cde”,“eee”]
输出1: 3

示例2:

输入:strs = [“aabbcc”,“aabbcc”,“c”]
输出: -1

题目分析:

在解题时,应用到一个重要的性质,即如果一个字符串s的子序列s1是特殊序列,则该字符串s也是特殊序列。反过来说,也就是若一个字符串s不是不是特殊序列的话,那它一定是某个字符串的子序列。这样我们在求解过程中只需要知道一个字符串不是其他所有字符串的子序列,那么它就是一个特殊序列。
另外在题目中要求求最长特殊序列,那么我们可以应用按照字符串长度排序来优化字符串中的“最长”查找问题。

示例代码:

public:
    //a是否是b的子串
    //a若是b的子串,则a的长度必然不超过b的长度
    bool isSubstr(string &a,string &b){
        if(a==b)    return true;
        int i=0;
        for(auto c:b){
            if(i<a.size() && a[i]==c)
                i++;
        }
        return (i==a.size());
    }
    int findLUSlength(vector<string>& strs) {
        sort(strs.begin(),strs.end(),[](string a,string b){
            return a.size()>b.size();
        });
        for(unsigned int i =0;i<strs.size();i++){
            bool flag = false;
            //检索字符串strs[i]是否是某个字符串的子串
            for(unsigned int j=0;j<strs.size()&&strs[i].size()<=strs[j].size();j++){
                if(i!=j && isSubstr(strs[i],strs[j])){
                    flag = true;
                    break;
                }  
            }
            if(!flag)    return strs[i].size();
        }
        return -1;
    }
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值