python练习 之 实践出真知 中心扩展法求最大回文子串 (leetcode题目)

1 问题,给定一个字符串,求字符串中包含的最大回文子串,要求O复杂度小于n的平方。

    首先需要解决奇数偶数的问题,办法是:插入’#‘,aba变成#a#b#a#,变成奇数个,aa变成#a#a#,变成奇数个。

    其次要解决指导思想问题,这个方法的切入点是奇数的回文字符串具有对称性,就像圆形一样,所以我们就可以迭代圆心,把具有对称性的点到圆心的距离想象成半径。所以需要两个迭代,一个迭代字符串中的点,另一个从半径为1开始,到超出字符串范围为止迭代字符串的半径。

   

#!/usr/binp/python
#!coding=utf-8-

def max_substr(string):
    alist=list(string)
    astr='#'+'#'.join(alist)+'#'
    br=1
    result=''
    point = 0
    for index in range(len(astr)):
        r = longest_r(astr,index)
        if r >= br:
            br=r
            point = index
    for i in astr[point-br:point+br+1]:
        if i != '#':
            result = result + i
    return result


def longest_r(astr,index):
    k=0
    for i in range(1,index+1):    #此处用1不用0的原因是:astr是加过井号的,所以最小的半径是1
        if index+i<len(astr) and index-i>=0 and astr[index-i]==astr[index+i]:
            k+=1
        else:
            break
    return k

if __name__ == "__main__":
    result1=max_substr('a')
    print result1

2 优化

    上面程序的思想是,在for index in range(len(string))的index中迭代i(也就是半径)每个index都从半径为1开始迭代,直到求出最大的半径,然后返回最大半径对应的点,切片求出回文子串。

    如果想优化的话,可以尝试标记目前已知的最大半径,然后index迭代的时候判断如果按照目前的最大半径切片,其是否是回文字符串,如果是,半径加1继续迭代,并且更新目前已知的最大半径,如果不是,那就迭代下一个index,直到最后。

    

 

posted @ 2018-07-17 23:19  0点0度  阅读(228)  评论(0编辑  收藏  举报