栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > C/C++/C#

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

C/C++/C# 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

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& strs) {
        sort(strs.begin(),strs.end(),[](string a,string b){
            return a.size()>b.size();
        });
        for(unsigned int i =0;i
转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/767759.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号