获取string中的最长回文字符串

例题

获取string中的最长回文字符串

所谓回文字符串,即该字符串从左到右读和从右到左读是完全一样的。如“123454321”就是一个长度为9的回文字符串。
现要求使用python完成:对一个字符串s,找出其中为回文字符串的部分,并返回回文字符串的长度。规则为:
1. 如果s是1个字符,则长度为1,如“a”
2. 如果s为空“”,则长度为0
3. 如果s中有部分是回文字符串,返回最长回文字符串及其长度,如“aab”,最长回文字符串为“aa”,长度为2

例子:

“a” -> 1
“aab” -> 2
“abcde” -> 1
“zzbaabcd” -> 4
“” -> 0

解法

对该字符串的每个长度的组合都进行比较,如果是回文字符串,记录其长度。返回最长的回文字符串

#!/usr/bin/env python3
# -*- coding: utf-8 -*-

def longest_palindrome (s):
    longest = 0
    if s == '': return ''
    for left in range(len(s)):
        for right in range(len(s), left, -1):
            if s[left:right] in (s[left:right])[::-1]:
                #longest = max(right-left, longest)
                if (right-left)>longest:
                    longest = right-left
                    palindrome = s[left:right]
                    break
                else: break
    return palindrome

if __name__ == "__main__":
    assert longest_palindrome('abcdab123454321') == '123454321'
    assert len(longest_palindrome('abcdab123454321')) == 9
    assert longest_palindrome('ab') == 'a'
    assert len(longest_palindrome('ab')) == 1
    assert longest_palindrome('aa') == 'aa'
    assert len(longest_palindrome('aa')) == 2
    assert longest_palindrome('') == ''
    assert len(longest_palindrome('')) == 0
    assert longest_palindrome('abcdefba') == 'a'
    assert len(longest_palindrome('abcdefba')) == 1

    print('assert complete!')

运行结果:

C:\Anaconda3\python.exe E:/python_projects/test.py
assert complete!

Process finished with exit code 0
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值