leetcode 131. 分割回文串
一、题目
给你一个字符串 s,请你将 s 分割成一些子串,使每个子串都是 回文串 。返回 s 所有可能的分割方案。
回文串 是正着读和反着读都一样的字符串。
示例 1:
输入:s = "aab"
输出:[["a","a","b"],["aa","b"]]
二、解法
思路:回溯。
其中需要判断s[i:j]是否是回文串。可以用动态规划来存储。
class Solution {
List<List<String>> ans=new ArrayList<>();
List<String> cur=new ArrayList<>();
boolean[][] f;
public List<List<String>> partition(String s) {
int n=s.length();
f=new boolean[n][n];
for(int i=0;i<n;i++){
for(int j=0;j<n;j++) f[i][j]=true;
}
for(int i=n-1;i>=0;i--){
for(int j=i+1;j<n;j++){
f[i][j]=f[i+1][j-1]&&s.charAt(i)==s.charAt(j);
}
}
dfs(s,0);
return ans;
}
void dfs(String s,int index){
if(index==s.length()){
ans.add(new ArrayList<>(cur));
return;
}
for(int i=index;i<s.length();i++){
String str=s.substring(index,i+1);
if(f[index][i]){
cur.add(str);
dfs(s,i+1);
cur.remove(cur.size()-1);
}
}
}
}
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· 阿里巴巴 QwQ-32B真的超越了 DeepSeek R-1吗?
· 【译】Visual Studio 中新的强大生产力特性
· 10年+ .NET Coder 心语 ── 封装的思维:从隐藏、稳定开始理解其本质意义
· 【设计模式】告别冗长if-else语句:使用策略模式优化代码结构