CCCC L2-008. 最长对称子串

时间:2023-03-08 22:12:40

https://www.patest.cn/contests/gplt/L2-008

题解:想法是扫一遍string,将每一个s[i]作为对称轴,写一个判定函数:不断向两边延伸直到不是回文串为止。

然后发现没有考虑形如werrew的回文串,所以改了一下,注意两个判定函数的循环方式

#include <iostream>
#include <cstdio>
#include <algorithm>
#include <queue>
#include <vector>
#include <cmath>
#include <cstring>
#include <string>
#include <map>
#include<stack>
#include<set>
#include<string.h>
#include<list>
#define pb push_back
#define mp make_pair
#define _for(i, a, b) for (int i = (a); i<(b); ++i)
#define _rep(i, a, b) for (int i = (a); i <= (b); ++i) using namespace std;
const int N = + ;
int len;
string s;
int test(int i) {
int l =i, r = i;
int cnt = ;
while (l- >= && r +<= len-) {
l--; r++;
if (s[l] == s[r])cnt++;
else break;
}
return cnt;
}
int test2(int i) {
int l = i, r = i + ;
int cnt = ;
while (l >= && r <= len - ) {
if (s[l] == s[r])cnt++;
else break;
l--; r++; }
return cnt;
}
int main() { getline(cin, s);
len = s.length();
int mx = ;
//1000*500
_for(i, , len) {
mx = max(mx, test(i));
} int ans=mx*+;
mx = ;
_for(i, , len) {
mx = max(mx, test2(i));
}
ans = max(ans, mx * );
cout << ans << endl;
system("pause");
}
/*qwerrewq*/