兩種解法,動態規劃和KMP變種數組
動態規劃,相似於lcs的解法,數組flag[i][j]記錄s從i到j是否是迴文spa
首先初始化,i>=j時,flag[i][j]=true,這是由於s[i][i]是單字符的迴文,當i>j時,爲true,是由於有可能出現flag[2][1]這種狀況,好比bcaa,當計算s從2到3的時候,s[2]==s[3],這時就要計算s[2+1] ?= s[3-1],總的來講,當i>j時置爲true,就是爲了考慮j=i+1這種狀況。code
接着比較s[i] ?= s[j],若是成立,那麼flag[i][j] = flag[i+1][j-1],不然直接flag[i][j]=falseblog
上代碼字符串
1 class Solution { 2 public: 3 string longestPalindrome(string s) { 4 int len = s.length(), max = 1, ss = 0, tt = 0; 5 bool flag[len][len]; 6 for (int i = 0; i < len; i++) 7 for (int j = 0; j < len; j++) 8 if (i >= j) 9 flag[i][j] = true; 10 else flag[i][j] = false; 11 for (int j = 1; j < len; j++) 12 for (int i = 0; i < j; i++) 13 { 14 if (s[i] == s[j]) 15 { 16 flag[i][j] = flag[i+1][j-1]; 17 if (flag[i][j] == true && j - i + 1 > max) 18 { 19 max = j - i + 1; 20 ss = i; 21 tt = j; 22 } 23 } 24 else flag[i][j] = false; 25 } 26 return s.substr(ss, max); 27 } 28 };
解法2:字符串s中的最長迴文串是s的倒轉s'和s的最長連續公共子串,代碼就不寫了string