LeetCode5题
思路:没有用特别高端的马拉车算法,用的是过年的时候学的动规算法。自己写的还是容易存在问题,此处算法有借鉴网友的算法。如果长度大于等于1,且正的和倒着相等([::-1]),则为一个回文串,将起始位置和最大长度都更改。
代码如下:
class Solution:
def longestPalindrome(self,s):
str_length = len(s)
max_length = 0
start = 0
for i in range(str_length):
if i - max_length >= 1 and s[i - max_length - 1:i + 2] == s[i - max_length - 1:i + 2][::-1]:
start = i - max_length - 1
max_length += 2
continue
if i - max_length >= 0 and s[i - max_length:i + 2] == s[i - max_length:i + 2][::-1]:
start = i - max_length
max_length += 1
return s[start:start + max_length+1]