Python找字符串中的最长回文子串

[本文出自天外归云的博客园]

问题:找出字符串中最长回文子串

我的思路:抛砖引玉。找出所有子串,挨个判断是不是回文,并记录最长的回文子串

代码如下:

复制代码
#!/usr/bin/python

def is_huiwen(s):
    low, high = 0, len(s)-1
    while low < high:
        if s[low] != s[high]:
            return False
        low += 1
        high -= 1
    return True

def get_longest_huiwen_sub(a):
    sub_longest = ""
    max_length = 0
    for i in range(len(a)):
        for j in range(i, len(a)):
            if j - i + 1 <= max_length:
                continue
            if is_huiwen(a[i:j+1]):
                max_length = len(a[i:j+1])
                sub_longest = a[i:j+1]
    return max_length, sub_longest
                
a= "abccbaab1233245"
max_length, sub_longest = get_longest_huiwen_sub(a)
print(max_length, sub_longest)
复制代码

 

posted @   天外归云  阅读(283)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 25岁的心里话
· 基于 Docker 搭建 FRP 内网穿透开源项目(很简单哒)
· 闲置电脑爆改个人服务器(超详细) #公网映射 #Vmware虚拟网络编辑器
· 一起来玩mcp_server_sqlite,让AI帮你做增删改查!!
· 零经验选手,Compose 一天开发一款小游戏!
历史上的今天:
2018-06-28 微信小程序测试指南
2018-06-28 JUnit+Mockito结合测试Spring MVC Controller
点击右上角即可分享
微信分享提示