题目描述:
给定字符串列表 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;
}