#week1# hihocoder 1032 最长回文子串

题目链接:http://hihocoder.com/problemset/problem/1032

1032 : 最长回文子串

时间限制: 1000ms
单点时限: 1000ms
内存限制: 64MB

描述

   小Hi和小Ho是一对好朋友,出生在信息化社会的他们对编程产生了莫大的兴趣,他们约定好互相帮助,在编程的学习道路上一同前进。

   这一天,他们遇到了一连串的字符串,于是小Hi就向小Ho提出了那个经典的问题:“小Ho,你能不能分别在这些字符串中找到它们每一个的最长回文子串呢?”

   小Ho奇怪的问道:“什么叫做最长回文子串呢?”

   小Hi回答道:“一个字符串中连续的一段就是这个字符串的子串,而回文串指的是12421这种从前往后读和从后往前读一模一样的字符串,所以最长回文子串的意思就是这个字符串中最长的身为回文串的子串啦~”

   小Ho道:“原来如此!那么我该怎么得到这些字符串呢?我又应该怎么告诉你我所计算出的最长回文子串呢?

   小Hi笑着说道:“这个很容易啦,你只需要写一个程序,先从标准输入读取一个整数N(N<=30),代表我给你的字符串的个数,然后接下来的就是我要给你的那N个字符串(字符串长度<=10^6)啦。而你要告诉我你的答案的话,只要将你计算出的最长回文子串的长度按照我给你的顺序依次输出到标准输出就可以了!你看这就是一个例子。”

提示一  提示二  提示三  提示四
样例输入
3
abababa
aaaabaa
acacdas
样例输出
7
5
3
1.超时代码(直接暴力的回文子串的中点,最坏情况下复杂度达到O(n2))

#include
using namespace std;
char str[1000005];
int solve(int i)
{
    int s = i-1, e = i+1;
    int ret = 1;
    while(str[s] == str[e])
        s--, e++, ret += 2;
    return ret;
}
int main()
{
    int T; scanf("%d", &T);
    while(T--)
    {
        str[0] = '$';
        scanf("%s", str+1);
        int ans = 0;
        for(int i = 1; i < strlen(str); i++)
        {
            ans = max(ans, solve(i));
        }
        cout << ans << endl;
    }
    return 0;
}


2.xiaoHO写的代码,自己感觉非常的经典,一个 i = e 省了好多时间,如果没有这一步,那么和第一个代码类似,也会TLE

#include
using namespace std;
char str[1000005];
int solve()        //str结尾处'\0'
{
    int ret = 1;
    for(int i = 1; str[i]; i++)
    {
        int s = i, e = i, t;
        while(str[e+1] == str[i]) e++;
        i = e;
        while(str[s-1] == str[e+1]) s--, e++;
        if((t = e - s + 1) > ret) ret = t;
    }
    return ret;
}
int main()
{
    int T; scanf("%d", &T);
    while(T--)
    {
        str[0] = '$';
        scanf("%s", str+1);
        int ans = solve();
        cout << ans << endl;
    }
    return 0;
}
3.标准的解决办法,,,,,,再补上

你可能感兴趣的:(ACM)