题解 | #密码截取#

密码截取

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

相关推荐

11-15 18:39
已编辑
西安交通大学 Java
全村最靓的仔仔:卧槽,佬啥bg呢,本也是西交么
点赞 评论 收藏
分享
23 2 评论
分享
牛客网
牛客企业服务