[USACO1.3] 最长的回文 Calf Flac
题目描述
据说如果你给无限只母牛和无限台巨型便携式电脑(有非常大的键盘 ), 那么母牛们会制造出世上最棒的回文。你的工作就是去寻找这些牛制造的奇观(最棒的回文)。
在寻找回文时不用理睬那些标点符号、空格(但应该保留下来以便做为答案输出), 只用考虑字母 A ∼ Z {\tt A}\sim {\tt Z} A∼Z 和 a ∼ z {\tt a}\sim {\tt z} a∼z。要你寻找的最长的回文的文章是一个不超过 20 , 000 20{,}000 20,000 个字符的字符串。我们将保证最长的回文不会超过 2 , 000 2{,}000 2,000 个字符(在除去标点符号、空格之前)。
输入格式
输入文件不会超过 20 , 000 20,000 20,000 字符。这个文件可能一行或多行,但是每行都不超过 80 80 80 个字符(不包括最后的换行符)。
输出格式
输出的第一行应该包括找到的最长的回文的长度。
下一行或几行应该包括这个回文的原文(没有除去标点符号、空格),把这个回文输出到一行或多行(如果回文中包括换行符)。
如果有多个回文长度都等于最大值,输出最前面出现的那一个。
样例 #1
样例输入 #1
Confucius say: Madam, I'm Adam.
样例输出 #1
11
Madam, I'm Adam
提示
题目翻译来自NOCOW。
USACO Training Section 1.3
代码(87分)
#include<cstdio>
#include<cmath>
#include<string>
using namespace std;
const int N = 2e4+10;
char a[N],b[N];
int c[N];
int ans1,ans2;
int n,l;
int res;
int main(){
while((a[n]=getchar())!=EOF)n++;
for(int i=0;i<n;i++){
if(isalpha(a[i])){
b[l]=tolower(a[i]);
c[l++]=i;
}
}
//区间暴力找回文数方法
for(int i=0;i<l;i++){
string A,B;
for(int j=i;j<l;j++){
A+=b[j];
B=b[j]+B;
// cout<<A<<" "<<B<<endl;
if(A==B){
// res=max(res,A.size());
int k=A.size();
if(res<k){
res=k;
ans1=c[i];
ans2=c[i+k-1];
// cout<<A<<endl;
}
}
}
}
// cout<<n<<endl;
printf("%d\n",res);
// for(int i=ans1;i<l;i++){
// cout<<c[i]<<" ";
// }
// cout<<endl;
// cout<<ans1<<" "<<ans2;
for(int i=ans1;i<=ans2;i++){
printf("%c",a[i]);
}
return 0;
}
待解决