给你一个字符串 s,请你将 s 分割成一些 子串,使每个子串都是 回文串 。返回 s 所有可能的分割方案。
示例 1:
输入:s = "aab"
输出:[["a","a","b"],["aa","b"]]
示例 2:
输入:s = "a"
输出:[["a"]]
提示:
1 <= s.length <= 16
s 仅由小写英文字母组成
思路 :枚举分割的位置。判断分割后的字符串是否为回文串,是就保存当前字符串,继续分割剩下的字符串。
代码:
c
class Solution {
public List<List<String>> partition(String s) {
List<List<String>> res = new ArrayList<>();
dfs(s, new ArrayList<String>(),res);
return res;
}
public void dfs(String s,List<String> temp, List<List<String>> res){
if(s.isEmpty()){
res.add(new ArrayList<>(temp));
return;
}
// 枚举分割位置
for(int i = 1;i<=s.length();i++){
String t = s.substring(0,i);
if(isHuiWen(t)){
temp.add(t);
dfs(s.substring(i),temp,res);
temp.remove(temp.size()-1);
}
}
}
public boolean isHuiWen(String a){
if(a.isEmpty()){
return false;
}
int left = 0;
int right = a.length()-1;
while(left<right){
if(a.charAt(left)!=a.charAt(right)){
return false;
}
left++;
right--;
}
return true;
}
}