【LeetCode 5 动态规划】最长回文子串

1. 题目

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

1.1 示例

  • 示例 1 1 1

    • 输入: s = "babad"
    • 输出: "bab"
    • 解释: "aba" 同样是符合题意的答案。
  • 示例 2 2 2

    • 输入: s = "cbbd"
    • 输出: "bb"

1.2 说明

1.3 限制

  • 1 <= s.length <= 1000
  • s 仅由数字和英文字母组成

2. 解法一(暴力求解法)

2.1 分析

本题使用暴力求解的方法很简单,即枚举出 s 的所有可能子串,找到其中一个最长的回文串即可。

针对下面实现,需要注意的是,使用了一个单独封装的方法 _is_palindrome() 来判断从给定字符串 s 的索引 leftright 之间确定的子串是否为回文串。

2.2 解答

class Solution:
    def _is_palindrome(self, s: str, left: int, right: int) -> bool:
        while left < right:
            if s[left] != s[right]:
                return False
            left += 1
            right -= 1
        return True

    def longest_palindrome(self, s: str) -> str:
        s_length = len(s)
        p_length = 0
        p_start = p_stop = 0
        for i in range(s_length):
            for j in range(i, s_length):
                if self._is_palindrome(s, i, j) and j - i + 1 > p_length:
                    p_length = j - i + 1
                    p_start = i
                    p_stop = i + p_length
        return s[p_start:p_stop]


def main():
    sln 
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值