怎么在Python中找回文子串?相信很多沒有經(jīng)驗的人對此束手無策,為此本文總結(jié)了問題出現(xiàn)的原因和解決方法,通過這篇文章希望你能解決這個問題。
在環(huán)江等地區(qū),都構(gòu)建了全面的區(qū)域性戰(zhàn)略布局,加強(qiáng)發(fā)展的系統(tǒng)性、市場前瞻性、產(chǎn)品創(chuàng)新能力,以專注、極致的服務(wù)理念,為客戶提供網(wǎng)站建設(shè)、成都網(wǎng)站設(shè)計 網(wǎng)站設(shè)計制作專業(yè)公司,公司網(wǎng)站建設(shè),企業(yè)網(wǎng)站建設(shè),高端網(wǎng)站設(shè)計,成都全網(wǎng)營銷,成都外貿(mào)網(wǎng)站建設(shè),環(huán)江網(wǎng)站建設(shè)費用合理。
Python主要應(yīng)用于:1、Web開發(fā);2、數(shù)據(jù)科學(xué)研究;3、網(wǎng)絡(luò)爬蟲;4、嵌入式應(yīng)用開發(fā);5、游戲開發(fā);6、桌面應(yīng)用開發(fā)。
1、雙指針兩邊擴(kuò)展
遍歷指針為i, j=i+1, i左移,j右移。判斷是否相等將長度,下標(biāo)賦給臨時變量,最后切片返回。唯一的大坑。回文字符串長度可以是奇數(shù)也可以是偶數(shù)。奇數(shù)的時候,內(nèi)層循環(huán)從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): # 長度為偶數(shù)的回文字符串 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 # 長度為奇數(shù)的回文子串 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]
2、Manacher算法
由于在輸入預(yù)處理的步驟中,將所有的回文子字符已經(jīng)轉(zhuǎn)為奇數(shù)長度。所以在下面的操作中,只需要將輸入的每一個字符,都當(dāng)做一個回文子字符的中心位即可。不需要考慮偶數(shù)長度的回文子字符。
''' @author: Yizhou Zhao ''' # 設(shè)置 radius[i] = 1, 因為字符本身也是一個回文數(shù) radius[i] = 1 while(string[i-radius[i]] == string[i+radius[i]]): radius[i] += 1
看完上述內(nèi)容,你們掌握怎么在Python中找回文子串的方法了嗎?如果還想學(xué)到更多技能或想了解更多相關(guān)內(nèi)容,歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道,感謝各位的閱讀!