[Jobdu] 题目1528:最长回文子串

时间:2023-01-31 09:52:08
题目描述:

回文串就是一个正读和反读都一样的字符串,比如“level”或者“noon”等等就是回文串。
回文子串,顾名思义,即字符串中满足回文性质的子串。
给出一个只由小写英文字符a,b,c...x,y,z组成的字符串,请输出其中最长的回文子串的长度。

输入:

输入包含多个测试用例,每组测试用例输入一行由小写英文字符a,b,c...x,y,z组成的字符串,字符串的长度不大于200000。

输出:

对于每组测试用例,输出一个整数,表示该组测试用例的字符串中所包含的的最长回文子串的长度。

样例输入:
abab
bbbb
abba
样例输出:
3
4
4

腾讯面试题,max_len初始为1,设为0会出错。

 #include <iostream>
#include <string>
using namespace std; int get_lps_len(string &s, int a, int b) {
int len = (a == b) ? - : ;
while (a >= && b < s.length() && s[a] == s[b]) {
--a; ++b;
len += ;
}
return len;
} int main() {
string s;
int max_len, cur_len;
while (cin >> s) {
max_len = ;
for (int i = ; i < s.length() - ; ++i) {
cur_len = get_lps_len(s, i, i);
max_len = max_len > cur_len ? max_len : cur_len;
cur_len = get_lps_len(s, i, i + );
max_len = max_len > cur_len ? max_len : cur_len;
}
cout << max_len << endl;
}
return ;
}