classSolution { public: string longestPalindrome(string s) { int i, j, len, end_idx, n = s.size(); int max_len = 1, reti = 0; // dp[i][j] 为0表示s[i..j]不是回文串,大于0表示j-i+1 vector<vector<int> > dp(n, vector<int>(n, 0));
for (i = 0; i < n; i++) { // len == 1 dp[i][i] = 1; }
len = 2; for (i = 0; i + len - 1 < n; i++) { // len == 2 if (s[i] == s[i + len - 1]) { dp[i][i + len - 1] = 2; if (dp[i][i + len - 1] > max_len) { max_len = dp[i][i + len - 1]; reti = i; } } }
for (len = 3; len <= n; len++) { for (i = 0; i + len - 1 < n; i++) { // s[i..i+len-1] end_idx = i + len - 1; if (s[i] == s[end_idx] && dp[i + 1][end_idx - 1] != 0) { dp[i][end_idx] = dp[i + 1][end_idx - 1] + 2; if (dp[i][end_idx] > max_len) { max_len = dp[i][end_idx]; reti = i; } } } }