对给定的字符串,本题要求你输出最长对称子串的长度。例如,给定
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;
}