【力扣521】最长特殊序列 Ⅰ

在这里插入图片描述

  • 专栏内容:力扣刷题
  • ⛪个人主页:子夜的星的主页
  • 座右铭:前路未远,步履不停

目录

  • 一、题目描述
  • 二、题目分析


一、题目描述

题目链接:最长特殊序列 Ⅰ

给你两个字符串 a 和 b,请返回这两个字符串中最长的特殊序列的长度。如果不存在,则返回 -1。

「最长特殊序列」定义如下:该序列为某字符串独有的最长子序列(即不能是其他字符串的子序列)字符串 s 的子序列是在从 s 中删除任意数量的字符后可以获得的字符串。

例如,"abc""aebdc" 的子序列,因为删除 "aebdc" 中斜体加粗的字符可以得到 "abc""aebdc" 的子序列还包括"aebdc""aeb""" (空字符串)。

【力扣521】最长特殊序列 Ⅰ_第1张图片

二、题目分析

仔细分析一下这道题目,这道题有三种情况。

  1. 长度不同的情况: 如果两个字符串的长度不同,那么较长的字符串本身就是最长特殊序列。因为较长的字符串中包含了较短字符串无法匹配的部分。

  2. 长度相同的情况: 如果两个字符串长度相同,且它们不相等,那么任意一个字符串都不是另一个字符串的子序列。因此,任意一个字符串都可以作为最长特殊序列。

  3. 相等的情况: 如果两个字符串相等,那么它们不存在特殊序列,返回 -1。

现在就要写清楚,什么时候两个字符串是相等的。在Java中,a.equals()String类的方法,用于比较两个字符串 ab 是否相等。

  • 如果 ab 引用的是同一个字符串对象,则返回 true
  • 如果 ab 是不同的字符串对象,但它们包含相同的字符序列,则也返回 true
  • 如果 ab 是不同的字符串对象,并且它们的字符序列不相同,则返回 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();
        }
    }
}

你可能感兴趣的:(#,力扣笔记,leetcode,算法)