Python算法題----取出最長迴文子串

Given a string S, find the longest palindromic substring in S. You may assume that the maximum length of S is 1000, and there exists one unique longest palindromic substring.


窮舉法

取出所有的子串組合,挨個判斷,返回最長的

class Solution(object):
    
    
    def isPalindrome(self, s, start, end):
        while start < end:
            if s[start] != s[end]:
                return False
            start += 1
            end -= 1
        return True
        
    def longestPalindrome(self, s):
        """
        :type s: str
        :rtype: str
        """
        max, left, right = 0, 0, 0
        for i in range(len(s)):
            j = i+1
            while j < len(s):
                if self.isPalindrome(s, i, j):
                    if (j-i+1) > max:
                        left, right = i, j
                        max = j - i + 1
                j += 1
        print left, right, max
        return s[left:right+1]


雙指針兩邊擴展

遍歷指針爲i, j=i+1, i左移,j右移。判斷是否相等將長度,下標賦給臨時變量,最後切片返回。唯一的大坑。迴文字符串長度可以是奇數也可以是偶數。奇數的時候,內層循環從i-1開始。邊界條件也需要處理好。

class Solution(object):
        
    def longestPalindrome(self, s):
        """
        :type s: str
        :rtype: str
        """
        n = len(s)
        maxL, maxR, max = 0, 0, 0
        for i in range(n):
            # 長度爲偶數的迴文字符串
            start = i
            end = i + 1
            while start >= 0 and end < n:
                if s[start] == s[end]:
                    if end - start + 1 > max:
                        max = end - start + 1
                        maxL = start
                        maxR = end
                    start -= 1
                    end += 1
                else:
                    break
    
            # 長度爲奇數的迴文子串
            start = i - 1
            end = i + 1
            while start >= 0 and end < n:
                if s[start] == s[end]:
                    if end - start + 1 > max:
                        max = end - start + 1
                        maxL = start
                        maxR = end
                    start -= 1
                    end += 1
                else:
                    break
        return s[maxL:maxR+1]


發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章