美文网首页
leetcode5-最长回文子串

leetcode5-最长回文子串

作者: 编号3577298 | 来源:发表于2021-11-29 02:09 被阅读0次

以每个位置为中心,向两头扩散。分两种情况:1,以数为中心扩散,解决奇数长度的子串;2,以两数间空格为中心扩散,解决偶数长度的子串。
采用递归法判断每个位置的最长子串有多长。

class Solution:
    def longestPalindrome(self, s: str) -> str:
        max_len = 1
        c = 0
        for i in range(len(s)):
            odd_n = self.judge_odd(s, i)
            even_n = self.judge_even(s, i)
            tmp = max(odd_n, even_n, max_len)
            if tmp != max_len:
                c = i
                max_len = tmp
        start = c - max_len // 2
        return s[start:start+max_len]
    
    def judge_odd(self, s, i, step=1):
        if i - step < 0 or i + step > len(s) - 1 or s[i-step] != s[i+step]:
            return (step - 1) * 2 + 1
        return self.judge_odd(s, i, step + 1)
    
    def judge_even(self, s, i, step=1):
        if i - step < 0 or i + step - 1> len(s) - 1 or s[i-step] != s[i+step-1]:
            return (step - 1) * 2
        return self.judge_even(s, i, step + 1)

相关文章

  • leetcode5-最长回文子串

    以每个位置为中心,向两头扩散。分两种情况:1,以数为中心扩散,解决奇数长度的子串;2,以两数间空格为中心扩散,解决...

  • 最长回文子串

    最长回文子串——Manacher 算法 1. 问题定义 最长回文字符串问题:给定一个字符串,求它的最长回文子串长度...

  • 字符串算法

    最长公共前缀 最长回文串 最长回文子序列 最长公共子串 反转单词顺序列 反转字符串 字符串转数字 IP-int互转

  • 打卡-最长回文子串

    最长回文子串(中等)

  • 最长回文子序列

    该问题区别于最长回文子串,子串必须是连续的,而子序列则可以跳跃,例如AABCAA的最长回文子串为AA,但是它的最长...

  • Manacher算法

    最长回文子串问题# 给定一个字符串,找出最长的回文子串,如"waabwswbfd",则最长子串为bwsb. 中心试...

  • 最长回文子串问题—Manacher算法

    最长回文串问题是一个经典的算法题。 0. 问题定义 最长回文子串问题:给定一个字符串,求它的最长回文子串长度。如果...

  • LeetCode 第647题:回文子串

    1、前言 2、思路 此题与最长回文子串很像,只不过那个是求最长的回文子串,而这个是求回文子串的数目。但是他们的解法...

  • C语言实现求最长回文子串

    最长回文子串的概念 回文串是指正序和反序都一样的字符串,例如:Str1 = "AbbA",则Str1的最长回文子串...

  • Manacher's Algorithm算法分析Java

    Manacher's Algorithm俗称马拉车算法,对于求字符串中最长回文子串效率极高。 在求最长回文子串的时...

网友评论

      本文标题:leetcode5-最长回文子串

      本文链接:https://www.haomeiwen.com/subject/eqekxrtx.html