题目
给你一个字符串 s,它仅由字母 ‘a’ 和 ‘b’ 组成。每一次删除操作都可以从 s 中删除一个回文 子序列。
返回删除给定字符串中所有字符(字符串为空)的最小删除次数。
「子序列」定义:如果一个字符串可以通过删除原字符串某些字符而不改变原字符顺序得到,那么这个字符串就是原字符串的一个子序列。
「回文」定义:如果一个字符串向后和向前读是一致的,那么这个字符串就是一个回文。
解题思路
先判断 s 是否为回文串,如果为回文串,那么删除一次即可。又因为 s 只由 a 和 b 组成,对于非回文串的情况,只需要先把 a 删完,再把 b 删完即可,也就是其他情况只需要两次就可以删完。注意这题说的子序列不是子串,不需要连在一起。麻了。
代码
class Solution {
public int removePalindromeSub(String s) {
for (int l = 0, r = s.length() - 1; l < r; l++, r--) {
if (s.charAt(l) != s.charAt(r)) {
return 2;
}
}
return 1;
}
}
删除回文子序列算法
678

被折叠的 条评论
为什么被折叠?



