zoukankan      html  css  js  c++  java
  • 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,直到最后。

        

  • 相关阅读:
    无熟人难办事?—迪米特法则
    考题抄错会做也白搭—模板方法模式
    简历复印—原型模式
    Android Studio 安装及常见问题
    雷锋依然在人间——工厂方法模式
    欢迎测试
    客户端程序设计V1
    Linux服务器端程序设计V1
    【Alpha】最后一篇
    【Alpha】开发日志Day10-0721
  • 原文地址:https://www.cnblogs.com/0-lingdu/p/9325771.html
Copyright © 2011-2022 走看看