一.题目描述
给定一个字符串 s,找到 s 中最长的回文子串。你可以假设 s 的最大长度为 1000。
示例 1:
输入: "babad"
输出: "bab"
注意: "aba" 也是一个有效答案。
示例 2:
输入: "cbbd"
输出: "bb"
二.代码如下:
class Solution:
def longestPalindrome(self, s: str) -> str:
Len=len(s)
Head=0
Tail=0
A=[[0 for i in range(Len)] for j in range(Len)]
for i in range(Len):
A[i][i]=1
if i<Len-1 and s[i]==s[i+1]:
Head=i
Tail=i+1
A[i][i+1]=1
MaxLen=0
for i in range(2,Len):
#这里的i表示的是这个子串的长度,因为必须求较短的子串的A再求较长子串的A
#这里得到A之后,也不用遍历A找最长的子串,使用变量Head和Tail记录最长的子串的起始位置和结束位置即可
for j in range(0,Len-i):
if s[j]==s[j+i] and A[j+1][j+i-1]==1:
if i>MaxLen:
Head=j
Tail=i+j
MaxLen=i
A[j][j+i]=1
else:
A[j][j+i]=0
return s[Head:Tail+1]
这是时间和空间复杂度都为O(n^2)的,空间复杂度还可以优化为O(n)