7-10 最长对称子串 (25 分)(暴力题解)C语言

对给定的字符串,本题要求你输出最长对称子串的长度。例如,给定Is PAT&TAP symmetric?,最长对称子串为s PAT&TAP s,于是你应该输出11。

输入格式:

输入在一行中给出长度不超过1000的非空字符串。

输出格式:

在一行中输出最长对称子串的长度。

输入样例:

Is PAT&TAP symmetric?

结尾无空行

输出样例:

11

结尾无空行

 思路:字符串末尾j=strlen(s)-1往前找到与前面i=0相同字符,然后判断前面字符和该匹配的字符区间

j-i+1内的字符是否满足回文,若满足,则更换max值为这个区间值j-i+1。若不满足则j往前找,找完一边后,i++继续执行前面操作

#include<stdio.h>
#include<string.h>
int main()
{
    char s[1002];
    gets(s);
    int max=1;
    for(int i=0;i<strlen(s);i++)
    {
        for(int j=strlen(s)-1;j>=0;j--)
        {
            int left=i,right=j;
            while(left<=right&&s[left++]==s[right--])//遍历left~right内元素
            {
                if(left>right)//当left~right范围内遍历完所有元素才执行条件
                {
                    if(max<j-i+1)
                    {
                        max=j-i+1;
                    }
                }
                    
            }
        }
    }
    printf("%d",max);
    return 0;
}

上一篇:养猪日记 2021.12.25


下一篇:【第25期】健康管理系统