Leetcode 1332:删除回文子序列(超详细的解法!!!)

给你一个字符串 s,它仅由字母 'a''b' 组成。每一次删除操作都可以从 s 中删除一个回文 子序列

返回删除给定字符串中所有字符(字符串为空)的最小删除次数。

「子序列」定义:如果一个字符串可以通过删除原字符串某些字符而不改变原字符顺序得到,那么这个字符串就是原字符串的一个子序列。

「回文」定义:如果一个字符串向后和向前读是一致的,那么这个字符串就是一个回文。

示例 1:

输入:s = "ababa"
输出:1
解释:字符串本身就是回文序列,只需要删除一次。

示例 2:

输入:s = "abb"
输出:2
解释:"abb" -> "bb" -> "". 
先删除回文子序列 "a",然后再删除 "bb"。

示例 3:

输入:s = "baabb"
输出:2
解释:"baabb" -> "b" -> "". 
先删除回文子序列 "baab",然后再删除 "b"。

示例 4:

输入:s = ""
输出:0

提示:

  • 0 <= s.length <= 1000
  • s 仅包含字母 ‘a’ 和 ‘b’

解题思路

这个问题的题目条件非常重要,字符串s只包含'a''b'两个字符。所以如果s是回文串的话,那么只要删除一次。如果s是空,那么不用删除。如果s不是回文,那么只需要删除两次(第一次删除所有的'a',第二次删除所有的'b'即可)。

class Solution:
    def removePalindromeSub(self, s: str) -> int:
        return 2 - (s == s[::-1]) - (s == "")

我将该问题的其他语言版本添加到了我的GitHub Leetcode

如有问题,希望大家指出!!!

发布了731 篇原创文章 · 获赞 457 · 访问量 83万+

猜你喜欢

转载自blog.csdn.net/qq_17550379/article/details/104133912