每日一题:最长回文字串 by python(19.9.18)

 

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

示例 1

输入: "babad"

输出: "bab"

注意: "aba"也是一个有效答案。

输入: "cbbd"

输出: "bb"

返回最长回文子串或最长子串的长度

def longeststr(s):
    k = len(s)  # 计算字符串的长度
    matrix = [[0 for i in range(k)] for i in range(k)]  # 初始化n*n的列表
    logestSubStr = ""  # 存储最长回文子串
    logestLen = 0  # 最长回文子串的长度
    for j in range(0, k):
        for i in range(0, j + 1):
            if j - i <= 1:
                if s[i] == s[j]:
                    matrix[i][j] = 1  # 此时f(i,j)置为true
                    if logestLen < j - i + 1:  # 将s[i:j]的长度与当前的回文子串的最长长度相比
                        logestSubStr = s[i:j + 1]  # 取当前的最长回文子串
                        logestLen = j - i + 1  # 当前最长回文子串的长度
            else:
                if s[i] == s[j] and matrix[i + 1][j - 1]:  # 判断
                    matrix[i][j] = 1
                    if logestLen < j - i + 1:
                        logestSubStr = s[i:j + 1]
                        logestLen = j - i + 1
        return logestSubStr

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值