131. 分割回文串
问题
给你一个字符串 s,请你将 s 分割成一些子串,使每个子串都是 回文串 。返回 s 所有可能的分割方案。
回文串 是正着读和反着读都一样的字符串。
示例 1:
输入:s = “aab”
输出:[[“a”,“a”,“b”],[“aa”,“b”]]
示例 2:
输入:s = “a”
输出:[[“a”]]
解决
回溯
class Solution:
def partition(self, s: str) -> List[List[str]]:
self.isPalindrome = lambda s: s==s[::-1]
res=[]
self.backtrack(s,res,[])
return res
def backtrack(self,s,res,path):
# 未探索区域满足结束条件,直接保存path,并退出
if not s:
res.append(path)
return
# 选择可能的场景
for i in range(1,len(s)+1):
if self.isPalindrome(s[:i]):
self.backtrack(s[i:],res,path+[s[:i]])
1094

被折叠的 条评论
为什么被折叠?



