- 专栏内容:力扣刷题
- ⛪个人主页:子夜的星的主页
- 座右铭:前路未远,步履不停
题目链接:最长特殊序列 Ⅰ
给你两个字符串 a 和 b,请返回这两个字符串中最长的特殊序列的长度。如果不存在,则返回 -1。
「最长特殊序列」定义如下:该序列为某字符串独有的最长子序列(即不能是其他字符串的子序列)字符串 s 的子序列是在从 s 中删除任意数量的字符后可以获得的字符串。
例如,"abc"
是"aebdc"
的子序列,因为删除 "aebdc"
中斜体加粗的字符可以得到 "abc"
。 "aebdc"
的子序列还包括"aebdc"
、"aeb"
和 ""
(空字符串)。
仔细分析一下这道题目,这道题有三种情况。
长度不同的情况: 如果两个字符串的长度不同,那么较长的字符串本身就是最长特殊序列。因为较长的字符串中包含了较短字符串无法匹配的部分。
长度相同的情况: 如果两个字符串长度相同,且它们不相等,那么任意一个字符串都不是另一个字符串的子序列。因此,任意一个字符串都可以作为最长特殊序列。
相等的情况: 如果两个字符串相等,那么它们不存在特殊序列,返回 -1。
现在就要写清楚,什么时候两个字符串是相等的。在Java中,a.equals()
是String
类的方法,用于比较两个字符串 a
和 b
是否相等。
a
和 b
引用的是同一个字符串对象,则返回 true
。a
和 b
是不同的字符串对象,但它们包含相同的字符序列,则也返回 true
。a
和 b
是不同的字符串对象,并且它们的字符序列不相同,则返回 false
。class Solution {
public int findLUSlength(String a, String b) {
if(a.equals(b)){
return -1;
}
if(a.length() > b.length()){
return a.length();
}else{
return b.length();
}
}
}