给你一个字符串 s,请你将 s 分割成一些子串,使每个子串都是回文。
返回符合要求的 最少分割次数 。
示例 1:
输入:s = "aab"
输出:1
解释:只需一次分割就可将 s 分割成 ["aa","b"] 这样两个回文子串。
示例 2:
输入:s = "a"
输出:0
示例 3:
输入:s = "ab"
输出:1
代码
class Solution {
public:
int minCut(string s) {
int n=s.size();
vector<vector<int> >ans(n,vector<int>(n,true));
for(int i=n-1;i>=0;i--){
for(int j=i+1;j<n;j++){
ans[i][j]=(s[i]==s[j]) &&ans[i+1][j-1]; //判断i到j是否回文
}
}
vector<int> sol(n,INT_MAX);
for(int i=0;i<n;i++){
if(ans[0][i]) sol[i]=0; //如果0到i是回文
else{
for(int j=0;j<i;j++){
if(ans[j+1][i]){
sol[i]=min(sol[i],sol[j]+1); //0到i的最小分割次数
}
}
}
}
return sol[n-1];
}
};