5. Longest Palindromic Substring
solution
class Solution:
def longestPalindrome(self, s: str) -> str:
longest = 0
l = r = 0
for i in range(len(s)):
length, left ,right = self.pali(s, i, i) # 这个写法有点繁杂,只需要返回一个子串,然后选择最长的即可
if length > longest:
longest = length
l = left
r = right
length, left, right = self.pali(s, i, i+1)
if length > longest:
longest = length
l = left
r = right
return s[l:r+1]
def pali(self, s, l, r):
temp_length = 0
while l >=0 and r < len(s) and s[l] == s[r]:
if l == r:
temp_length += 1
else:
temp_length += 2
l -= 1
r += 1
return temp_length, l+1, r-1follow up-回文类
Previous209. Minimum Size Subarray SumNext395. Longest Substring with At Least K Repeating Characters
Last updated