给定一个字符串 s,将 s 分割成一些子串,使每个子串都是回文串。
返回 s 所有可能的分割方案。
示例:
输入: "aab" 输出: [ ["aa","b"], ["a","a","b"] ]
题目分析:DFS+回溯
代码展示:
class Solution {
public:
vector<vector<string>> partition(string s) {
vector<vector<string>> ans;
if(s.length()==0)
return ans;
vector<string> path;
dfs(ans,path,s,0);
return ans;
}
void dfs(vector<vector<string>>& ans,vector<string>& path,string s,int start){
if(start==s.length()){
ans.push_back(path);
return;
}
for(int i=start;i<s.length();i++){
if(isPali(s.substr(start,i-start+1))){
path.push_back(s.substr(start,i-start+1));
dfs(ans,path,s,i+1);
path.pop_back();
}
}
}
bool isPali(string str){
for(int i=0;i<str.length()/2;i++){
if(str[i]!=str[str.length()-i-1])
return false;
}
return true;
}
};