Leetcode131.分割回文串-Palindrome Patitioning-Python-回溯法

解题思路:

1.切割回文串,可以用解决找组合问题的思路解决,而解决组合问题,可以用回溯法,故本题选择回溯法。

2.理解两个事情:1.递归函数里的for循环是横向遍历给定字符串s的每一个字母。2.针对s的每一个字母,比如在切割了第一个字母之后,还有很多种切割方式,这是由不断的调用递归函数来实现的。

3.判断回文串。用双指针法即可。当然此题也可以用动态规划法,但是为了降低难度,我先不采用这个方法,知识点太多吃不消呀。

注意:

1.判断是回文串之后,如何确定s的索引来将回文串添加至path。因为在判断回文串时,传入的函数参数是startIndex,i。这是确认是否是回文串的索引下标,如果是回文串的话,其实索引startIndex不变,只需要将终止索引+1, 即i+1。例如'aab' startIndex==1, i==2,那么待判断的回文串就是ab.假设ab是回文串,那么索引 startIndex, i+1 就代表着aab的ab。So, do you understand?

复制代码
            if self.isPalinDrome(s, startIndex, i):
                self.path.append(s[startIndex:i+1])
            else:
                continue

代码:

复制代码
class Solution(object):
    result = []
    path = []
    
    def traceBacking(self, s, startIndex):
        if startIndex >= len(s):
            self.result.append(self.path[:])
            return
        for i in range(startIndex, len(s)):

            if self.isPalinDrome(s, startIndex, i):
                self.path.append(s[startIndex:i+1])
            else:
                continue
            
            self.traceBacking(s, i+1)
            self.path.pop()
        
    def isPalinDrome(self,s,startIndex, end):
        i = startIndex
        j = end
        while i<j:
            if s[i] != s[j]:
                return False
            i +=1
            j -=1
        return True

    def partition(self, s):
        self.result = []
        self.traceBacking(s, 0)
        return self.result
相关推荐
王中阳Go10 小时前
从超市收银到航空调度:贪心算法如何破解生活中的最优决策谜题?
java·后端·算法
Johny_Zhao11 小时前
CentOS Stream 8 高可用 Kuboard 部署方案
linux·网络·python·网络安全·docker·信息安全·kubernetes·云计算·shell·yum源·系统运维·kuboard
故事挺秃然11 小时前
中文分词:机械分词算法详解与实践总结
算法·nlp
站大爷IP11 小时前
精通einsum():多维数组操作的瑞士军刀
python
站大爷IP12 小时前
Python与MongoDB的亲密接触:从入门到实战的代码指南
python
Roc-xb12 小时前
/etc/profile.d/conda.sh: No such file or directory : numeric argument required
python·ubuntu·conda
车队老哥记录生活13 小时前
【MPC】模型预测控制笔记 (3):无约束输出反馈MPC
笔记·算法
地平线开发者13 小时前
BEV 感知算法评价指标简介
算法·自动驾驶
世由心生13 小时前
[从0到1]环境准备--anaconda与pycharm的安装
ide·python·pycharm
不过四级不改名67714 小时前
用c语言实现简易c语言扫雷游戏
c语言·算法·游戏