标签:子串 25 10 int 题解 AP 输出 max AT&T
对给定的字符串,本题要求你输出最长对称子串的长度。例如,给定
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;
}
标签:子串,25,10,int,题解,AP,输出,max,AT&T 来源: https://blog.csdn.net/weixin_52797843/article/details/122286988
本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享; 2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关; 3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关; 4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除; 5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。