题解 | #密码截取#

密码截取

http://www.nowcoder.com/practice/3cd4621963e8454594f00199f4536bb1

#include <stdio.h>
#include <string.h>

//颠倒后比较最长字段 XXX
//中心遍历
//增加遍历指针low high是遍历更加简洁
int main()
{
    char str[3000];
    scanf("%s", str);
    int len = strlen(str);
    int max[len][2];
    for (int i = 0; i < len; i++)
    {
        int low, high;
        //以i为中心奇数串
        low = i - 1, high = i + 1;
        max[i][0] = 1;
        while (low >= 0 && high < len && str[low] == str[high])
        {
            low--;
            high++;
            max[i][0] += 2;
        }
        //以i为中心偶数串
        low = i, high = i + 1;
        max[i][1] = 0;
        while (low >= 0 && high < len && str[low] == str[high])
        {
            low--;
            high++;
            max[i][1] += 2;
        }
    }

    int maxlen = 0;
    for (int i = 0; i < len; i++)
    {
        for (int j = 0; j < 2; j++)
        {
            if (max[i][j] > maxlen)
                maxlen = max[i][j];
        }
    }

    printf("%d", maxlen);

    return 0;
}
全部评论
牛逼666
点赞 回复 分享
发布于 2022-04-23 14:24

相关推荐

dachang盒子:26届秋招必须有实习经历,建议找个实习过度下,同时项目重复率也比较高没有什么难点亮点,我这里有大厂真实的项目可以提供给你学习也可以给你包装大厂实习来提高你的竞争力,感兴趣的话可以私信我或者点我主页简介
你已经投递多少份简历了
点赞 评论 收藏
分享
2025-11-26 09:37
山西大学 测试工程师
累死的一条狗:学长你电脑闹鬼了
点赞 评论 收藏
分享
评论
26
2
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务