- 题目
给你一个字符串 s,请你将 s 分割成一些子串,使每个子串都是 回文串 。返回 s 所有可能的分割方案。
- 示例
输入:s = “aab”
输出:[[“a”,“a”,“b”],[“aa”,“b”]]
- 算法
注释
- 代码
class Solution {
List<List<String>> res = new ArrayList<>();
List<String> cur = new ArrayList<>();
boolean[][] dp;
public void backTracking(String s, int index) {
// 如果子串的开头下标越界了,则找到了一个最终结果
if (index == s.length()) {
res.add(new ArrayList<>(cur));
return;
}
// 尝试 s[index...i]的子串
for (int i = index; i < s.length(); i++) {
// 如果不是回文串,则放弃
if (!dp[index][i]) {
continue;
}
cur.add(s.substring(index, i + 1));
backTracking(s, i + 1);
cur.remove(cur.size() - 1);
}
}
public List<List<String>> partition(String s) {
int n = s.length();
dp = new boolean[n][n];
for (int j = 0; j < n; j++) {
for (int i = 0; i <= j; i++) {
if (s.charAt(i) == s.charAt(j)
&& (j - 1 <= i + 1 || dp[i+1][j-1])) {
dp[i][j] = true;
}
}
}
backTracking(s,0);
return res;
}
}