LeetCode: 521. 最长特殊序列 Ⅰ

最长特殊序列 Ⅰ

原题

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

「最长特殊序列」 定义如下:该序列为 某字符串独有的最长子序列(即不能是其他字符串的子序列)

字符串 s 的子序列是在从 s 中删除任意数量的字符后可以获得的字符串。

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

示例 1:

复制代码
输入: a = "aba", b = "cdc"
输出: 3
解释: 最长特殊序列可为 "aba" (或 "cdc"),两者均为自身的子序列且不是对方的子序列。

示例 2:

复制代码
输入:a = "aaa", b = "bbb"
输出:3
解释: 最长特殊序列是 "aaa" 和 "bbb" 。

示例 3:

复制代码
输入:a = "aaa", b = "aaa"
输出:-1
解释: 字符串 a 的每个子序列也是字符串 b 的每个子序列。同样,字符串 b 的每个子序列也是字符串 a 的子序列。

提示:

  • 1 <= a.length, b.length <= 100
  • ab 由小写英文字母组成
Java 复制代码
class Solution {
    public int findLUSlength(String a, String b) {

    }
}

解题思路

最长特殊序列是指某字符串独有的最长子序列:

  • 如果两个字符串长度不一样,较长的字符串不会是较短字符串的子序列,直接返回其长度
  • 如果长度相同但字符串不同,它们也不会是互相的子序列,随便返回其中一个字符串的长度
  • 如果长度相同字符串也相同,任意字符串的每个子序列都会是另一个字符串的子序列,返回 -1

代码示例

Java 复制代码
class Solution {
    public int findLUSlength(String a, String b) {
        if (a.equals(b)) {
            return -1;
        } else {
            return Math.max(a.length(), b.length());
        }
    }
}
相关推荐
超级大只老咪2 分钟前
输入(java)
算法
jing-ya4 分钟前
day51 图论part3
数据结构·算法·深度优先·图论
盐水冰11 分钟前
【烘焙坊项目】后端搭建(6)- 店铺状态设置
java·redis
健康平安的活着13 分钟前
java中乐观锁+事务在批量导入,批量审批案例的使用
java·开发语言
夏语灬13 分钟前
SpringBoot集成MQTT客户端
java·spring boot·后端
AI浩15 分钟前
UTPTrack:迈向简单统一的视觉跟踪令牌剪枝
算法·机器学习·剪枝
Memory_荒年16 分钟前
Spring Boot自动装配:告别“配置地狱”的智能管家
java·后端·spring
nananaij24 分钟前
【LeetCode-02 最小偶倍数 python解法】
python·算法·leetcode
倾心琴心25 分钟前
【agent辅助pcb routing coding学习】实践4 kicad pcb 核心类层次关系
算法·agent·pcb·eda·routing
im_AMBER29 分钟前
Leetcode 139 最后一个单词的长度 | 找出字符串中第一个匹配项的下标
开发语言·算法·leetcode