最长回文子串(C语言)

题目:给你一个字符串s,找到s中最长的回文子串

提示:

1 <= s.length <= 1000;

s仅由数字和字母组成


回文字符串的特点是左右对称,因此可以利用这个特点遍历原字符串。在遍历每个元素时,应当考虑回文子串是奇数串还是偶数串。如果是奇数串,可以将当前元素作为中心,判断它与周围字符能否构成回文字符串;如果是偶数串,可以将两个连续的相同字符作为中心,判断这个中心与周围字符能否构成回文字符串。这里使用target数组记录最长回文字符串的首尾下标。

注意这里有个特殊情况,当字符串的长度小于3时,后面for循环访问数组时会越界。所以这里使用if(s_len<3)的条件处理。

char * longestPalindrome(char * s){
    int i, j=0, k=0, max=0, s_len, target[2]={0};
	s_len = strlen(s);
	if(s_len<3){
		if(s[0]==s[s_len-1]) return s;
		else return s+s_len-1;
	}
	for(i=0;i<s_len-1;i++){
		if(*(s+i)==*(s+i+1)){	//even
			j=0;
			while(i-j>=0&&i+j+1<s_len){
				if(*(s+i-j)!=*(s+i+1+j)) break;
				j++;
			}
			if(j*2>max){
				max = j*2;
				target[0] = i-(j-1);
				target[1] = i+j; //s+i+1+(j-1)
			}
		}
		if(*(s+i)==*(s+i+2)){   //odd
			j=0;
			while(i-j>=0&&i+j+2<s_len){
				if(*(s+i-j)!=*(s+i+2+j)) break;
				j++;
			}
			if(j*2+1>max){
				max = j*2 + 1;
				target[0] = i-(j-1);
				target[1] = i+2+(j-1);
			}
		}
	
	}
	s[target[1]+1] = 0;
    return s+target[0];
}

  • 0
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

diqiudq

人过留名,雁过留声。

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值