最长回文子串三种解法

最长回文子串

http://www.nowcoder.com/questionTerminal/b4525d1d84934cf280439aeecc36f4af

解法1,动态规划之带备忘(table)的自顶向下法,建立一个二维表table来记录A[i:j]是否是回文子串,若 table[i][j] == 1则A[1:j+1]为回文串。

# -*- coding:utf-8 -*-

class Palindrome:
    def getLongestPalindrome(self, A, n):
        # write code here
        if n <= 1:
            return n
        table = [[-1 for _ in range(n)] for __ in range(n)]
        for i in range(n):
            table[i][i] = 1
        res = [1]
        def f(left, right):
            if table[left][right] != -1:
                return table[left][right] == 1
            if left > right:
                return False
            if A[left] == A[right]:
                if 0 <= right - left <= 1 or f(left+1, right-1):
                    table[left][right] = 1
                    res[0] = max(res[0], right - left + 1)
                else:
                    table[left][right] = 0
                    f(left, right-1)
                    f(left+1, right)
            else:
                table[left][right] = 0
                f(left, right-1)
                f(left+1, right)
            return table[left][right] == 1
        f(0, n-1)
        return res[0]

解法2,自底向上法,以更短的回文子串为中心,向两边扩散,不需要建表,而且因为有剪枝处理,效率高。

# -*- coding:utf-8 -*-

class Palindrome:
    def getLongestPalindrome(self, A, n):
        # write code here
        def func(A, left, right):
            while left >=0 and right < n and A[left]==A[right]:
                left -= 1
                right += 1

            return right-left-1

        res = 0
        for i in range(n-1):
            res = max(res, func(A, i, i), func(A, i, i+1))
        return res

解法3,暴力法

# -*- coding:utf-8 -*-

class Palindrome:
    def getLongestPalindrome(self, A, n):
        # write code here
        if n <= 1:
            return n
        res = 1
        for i in range(0,n):
            if n - i <= res:
                return res
            for j in range(n - 1, i, -1):
                if A[j] == A[i]:
                    res = max(res, self.f(A[i:j+1]))


    def f(self, string):
        if string == string[::-1]:
            return len(string)

解法2为最优。

全部评论

相关推荐

牛客51274894...:照片认真的吗,找个专门拍证件照的几十块钱整端正点吧,要不就别加照片
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
正在热议
更多
# 长得好看会提高面试通过率吗? #
2950次浏览 42人参与
# HR最不可信的一句话是__ #
985次浏览 32人参与
# 米连集团26产品管培生项目 #
7001次浏览 224人参与
# 春招至今,你的战绩如何? #
14348次浏览 133人参与
# AI面会问哪些问题? #
874次浏览 21人参与
# 你的实习产出是真实的还是包装的? #
2588次浏览 52人参与
# MiniMax求职进展汇总 #
24823次浏览 321人参与
# 沪漂/北漂你觉得哪个更苦? #
1076次浏览 29人参与
# 你做过最难的笔试是哪家公司 #
1084次浏览 20人参与
# AI时代,哪个岗位还有“活路” #
2630次浏览 49人参与
# XX请雇我工作 #
51141次浏览 171人参与
# 军工所铁饭碗 vs 互联网高薪资,你会选谁 #
7950次浏览 43人参与
# 简历第一个项目做什么 #
32035次浏览 357人参与
# 简历中的项目经历要怎么写? #
310850次浏览 4257人参与
# 不考虑薪资和职业,你最想做什么工作呢? #
152795次浏览 888人参与
# 当下环境,你会继续卷互联网,还是看其他行业机会 #
187527次浏览 1123人参与
# AI时代,哪些岗位最容易被淘汰 #
64474次浏览 860人参与
# 如果重来一次你还会读研吗 #
229960次浏览 2011人参与
# 投格力的你,拿到offer了吗? #
178175次浏览 889人参与
# 你怎么看待AI面试 #
180611次浏览 1291人参与
# 正在春招的你,也参与了去年秋招吗? #
364105次浏览 2640人参与
# 腾讯音乐求职进展汇总 #
160808次浏览 1114人参与
牛客网
牛客网在线编程
牛客网题解
牛客企业服务