【132】求把字符串分割成回文串的最少切分次数

该博客讨论了如何求解将一个字符串分割成回文子串的最少分割次数,通过动态规划的方法,详细解析了状态转移方程和时间复杂度分析,并给出了LeetCode第132题的解决方案。
摘要由CSDN通过智能技术生成

给你一个字符串 s,请你将 s 分割成一些子串,使每个子串都是回文。

返回符合要求的 最少分割次数 。

 

示例 1:

输入:s = "aab"
输出:1
解释:只需一次分割就可将 s 分割成 ["aa","b"] 这样两个回文子串。
示例 2:

输入:s = "a"
输出:0
示例 3:

输入:s = "ab"
输出:1
 

提示:

1 <= s.length <= 2000
s 仅由小写英文字母组成

 

这道题是“求一个字符串的所有 ”回文串 那道题的拓展。如何求某个字符串的所有回文子串(或者是说求字符串最长回文子串是多长),用到了DP,也就是一个典型分阶段求最值问题:

1.首先对于求字符串所有回文串

明确状态转移方程:p(i,j)表示字符串从i开始到j结束是否为回文串,这里包括字符i和j

p(i,j) = p(i+1,j-1)  (s[i]==s[j])

当字符串长度为1或者2的时候,

i==j :p(i,j) = 1 

i==j-1: p(i,j) =

评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值