题目链接:http://acm.hdu.edu.cn/diy/contest_showproblem.php?cid=18800&pid=1003
题目分析:其实就是找最大的回文串,不过是对这个回文串有点附加的要求罢了。在o(n)求最大回文串,参考我的另一篇博客:http://blog.csdn.net/kay_zhyu/article/details/8712815
PS:这道题其实我没有AC过,每次都是wrong answer。人世间最郁闷的事就是你觉得程序没有任何问题,但是AC的时候,一直提示wrong answer。感觉我用很多例子测试都是对的啊。可能自己考虑得还不够全面。如果有大神路过,帮忙指点指点,菜鸟感激不尽。
#include <stdio.h>
#define M 200010
int p[M];
int str[M];
inline int min(int a, int b)
{
return a < b ? a : b;
}
void kp(int n)//找最长的回文
{
int i;
int mx = 0;
int ID;
for(i = 1; i < n; ++i)
{
if(mx > i)
{
p[i] = min(p[ID * 2 - i], mx - i);
}
else
{
p[i] = 1;
}
while((i - p[i] >= 1) && (i + p[i] < n) && (str[i - p[i]] == str[i + p[i]]))
{
if(str[i - p[i]] <= str[i - p[i] + 1] || str[i] == -1 ||
(str[i - p[i] + 1] == -1 && str[i - p[i]] <= str[i - p[i] + 2]))//这是针对这道题的附加条件附加的判断
{
++p[i];
}
else
{
break;
}
}
if(i + p[i] > mx)
{
mx = i + p[i];
ID = i;
}
}
}
void main()
{
int n;
int t;
int i;
scanf("%d",&t);
while(t--)
{
scanf("%d",&n);
str[0] = -2;
str[1] = -1;
i = 1;
while(n--)
{
scanf("%d",&str[++i]);
str[++i] = -1;
}
n = i + 1;
int nMax = 0;
kp(n);
for(int i = 1; i < n; ++i)
{
nMax = nMax > p[i] ? nMax : p[i];
}
printf("%d\n", nMax - 1);
}
}