IT俱乐部 Python Python最长回文子串问题

Python最长回文子串问题

Python最长回文子串

1.暴力解法(Brute Method)

暴力求解是最容易想到的,要截取字符串的所有子串,然后再判断这些子串中哪些是回文的,最后返回回文子串中最长的即可。

这里我们可以使用两个变量,一个记录最长回文子串开始的位置,一个记录最长回文子串的长度,最后再截取。

class Solution:
    def longestPalindrome(self, s):
        if (len(s) 

2.中心扩散法

从左向右遍历:选择一个中心点向两侧扩展,分别考虑奇数组合偶数组的情况。

class Solution:
    def longestPalindrome(self, s: str) -> str:
        #  判断空字符串的情况
        if (s == ""):
            return ""
        result = ""
        sSize = len(s)
        # 选择一个中心点,向两侧扩展
        for i in range(sSize):
            # 奇数组情况
            tmpStr = self.expandHelper(s, i, i)
            # 偶数组情况
            tmpStr2 = self.expandHelper(s, i, i + 1)
            if len(tmpStr) > len(result):
                result = tmpStr
            if len(tmpStr2) > len(result):
                result = tmpStr2
        return result
 
    def expandHelper(self,s,left,right):
        sSize = len(s)
        while (left >= 0 and right 

3.动态规划

思路与算法

对于一个子串而言,如果它是回文串,并且长度大于 22,那么将它首尾的两个字母去除之后,它仍然是个回文串。例如对于字符串 “ababa”,如果我们已经知道 “bab” 是回文串,那么 “ababa” 一定是回文串,这是因为它的首尾两个字母都是 “a”。

注意:在状态转移方程中,我们是从长度较短的字符串向长度较长的字符串进行转移的,因此一定要注意动态规划的循环顺序。 

class Solution:
    def longestPalindrome(self, s):
        n = len(s)
        if n = n:
                    break
 
                if s[i] != s[j]:
                    dp[i][j] = False
                else:
                    if j - i  max_len:
                    max_len = j - i + 1
                    begin = i
        return s[begin:begin + max_len]
 
 
s = "abaa"
S = Solution()
result = S.longestPalindrome(s)
print(result)

python练习–最长回文子串

题目描述

给你一个字符串 s,找到 s 中最长的回文子串。

示例:

输入:s = “babad”
输出:“bab”
解释:“aba” 同样是符合题意的答案。

输入:s = “cbbd”
输出:“bb”

输入:s = “a”
输出:“a”

输入:s = “ac”
输出:“a”

提示:

1

s 仅由数字和英文字母(大写和/或小写)组成

解题思路

中心扩展法:

把每个字母(或者数字)当成回文串的中心,这里要考虑两种情况,回文串的长度为奇数或者偶数情况。

从每一个位置出发,向两边扩散即可。传递下去的条件是s[L]==s[R];

遇到不是回文的时候结束。

eg: str = “acdbbdaa”。需要寻找从第一个b(位置为3)出发最长回文串为多少。

寻找方法:

首先往左寻找与当期位置相同的字符,直到遇到不相等为止。

然后往右寻找与当期位置相同的字符,直到遇到不相等为止。

最后左右双向扩散,直到左和右不相等。

代码

class Solution:
    def longestPalindrome(self, s: str) -> str:
        if not s :
            return ""
        res = ""
        n = len(s)
        dp = [[0] * n for _ in range(n)]
        max_len = float("-inf")
        for i in range(n):
            for j in range(i + 1):
                if s[i] == s[j] and (i - j 

因为我们最后要返回的是具体子串,而不是长度,因此,还需要记录一下maxLen时的起始位置(maxStart),即此时还要maxStart=len

大佬的代码

class Solution:
    def longestPalindrome(self, s: str) -> str:
        n = len(s)
        if n  str:
            while 0  len(even_str):    #若长度为奇数的长
                if len(odd_str) > max_len:
                    max_len = len(odd_str)
                    res = odd_str
            else:                               #若长度为偶数的长
                if len(even_str) > max_len:
                    max_len = len(even_str)
                    res = even_str
        
        return res

以上为个人经验,希望能给大家一个参考,也希望大家多多支持IT俱乐部。

本文收集自网络,不代表IT俱乐部立场,转载请注明出处。https://www.2it.club/code/python/1720.html
上一篇
下一篇
联系我们

联系我们

在线咨询: QQ交谈

邮箱: 1120393934@qq.com

工作时间:周一至周五,9:00-17:30,节假日休息

关注微信
微信扫一扫关注我们

微信扫一扫关注我们

返回顶部