美文网首页leetcode
最长回文子串

最长回文子串

作者: momo1023 | 来源:发表于2018-09-06 22:19 被阅读12次

最长回文子串

给定一个字符串 s,找到 s 中最长的回文子串。你可以假设 s 的最大长度为1000。

输入: "babad"
输出: "bab"
注意: "aba"也是一个有效答案。

输入: "cbbd"
输出: "bb"
class Solution:
    def longestPalindrome(self, s):
        """
        :type s: str
        :rtype: str
        """
        if not s or len(s)==1:
            return s

        result = ''
        maxlen = 0
        for i in range(len(s)):
            for x in range(maxlen,len(s) - i):
                tsr = s[i:i+x+1]
                rtsr = tsr[::-1]
                if tsr == rtsr and len(tsr) > maxlen:
                    maxlen = len(tsr)
                    result = tsr

        return result
# manacher算法
def manacher(self):
        s = '#' + '#'.join(self.string) + '#'               # 字符串处理,用特殊字符隔离字符串,方便处理偶数子串
        lens = len(s)
        f = []                                          # 辅助列表:f[i]表示i作中心的最长回文子串的长度
        maxj = 0                                        # 记录对i右边影响最大的字符位置j
        maxl = 0                                        # 记录j影响范围的右边界
        maxd = 0                                        # 记录最长的回文子串长度
        for i in range(lens):                           # 遍历字符串
            if maxl > i:
                count = min(maxl-i, int(f[2*maxj-i]/2)+1)  # 这里为了方便后续计算使用count,其表示当前字符到其影响范围的右边界的距离
            else :
                count = 1
            while i-count >= 0 and i+count < lens and s[i-count] == s[i+count]:  # 两边扩展
                count += 1
            if(i-1+count) > maxl:                         # 更新影响范围最大的字符j及其右边界
                maxl, maxj = i-1+count, i
            f.append(count*2-1)
            maxd = max(maxd, f[i])                       # 更新回文子串最长长度
        return int((maxd+1)/2)-1                        # 去除特殊字符

相关文章

  • 最长回文子串

    最长回文子串——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俗称马拉车算法,对于求字符串中最长回文子串效率极高。 在求最长回文子串的时...

  • Manacher 算法学习笔记

    前言 给定一个字符串,求出其最长回文子串。例如:s="abcd",最长回文长度为 1;s="ababa",最长回文...

网友评论

    本文标题:最长回文子串

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