python求最长回文子串

原理可参考链接:https://blog.csdn.net/sinat_35261315/article/details/78267046?spm=1001.2101.3001.6650.1&utm_medium=distribute.pc_relevant.none-task-blog-2%7Edefault%7ECTRLIST%7ERate-1.pc_relevant_aa&depth_1-utm_source=distribute.pc_relevant.none-task-blog-2%7Edefault%7ECTRLIST%7ERate-1.pc_relevant_aa&utm_relevant_index=2


# 最大回文子串
def LongestPlindromeSubseq(str):
    if len(str) <= 1:
        return str
    ans = ''
    # 以extend_s[i]为中心,向两边扩展,这个extend_s[i]既有可能是#,也有可能是字母
    for i in range(2*len(str)+1):
        ans = Find_Plindrome(i-1,i+1,str,ans)
    return ans

def Find_Plindrome(l_idx,r_idx,str,ans):
    # 判断边界,从中间往两边查找,遇到左右不相等说明回文断开,就停止
    while l_idx>=0 and r_idx<2*len(str)+1:
        # 的下标永远是偶数,所以判断是否是奇数,然后比较s中的两个字符
        if l_idx%2!=0 and r_idx%2!=0 and str[l_idx//2]!=str[r_idx//2]:
            break
        l_idx -= 1
        r_idx += 1
    '''
         * 这是为了解决边界0的问题,因为如果找到左边界(0)时仍然相等,那么l_idx会是-1
         * 因为找到的回文子串应该是s[l_idx / 2 + 1, r_idx / 2]
         * 由于l_idx是-1,-1/2==0,正常结果应该是s[0, r_idx / 2 - 1],
         * 会导致l_idx / 2 + 1 == 1,不为0,使结果长度变小
    '''
    l_idx = -2 if l_idx is -1 else l_idx
    l_idx_ = l_idx//2 + 1
    r_idx_ = r_idx//2
    if len(ans) < r_idx_ - l_idx_:
        ans = str[l_idx_:r_idx_]
    return ans

str = 'abcbcb'
print(LongestPlindromeSubseq(str))

在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Shashank497

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值