力扣题解(最长回文子串)

5. 最长回文子串

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

。思路:

对于第i个字符,可能的回文子串构成方式有两种,一种是以i位置元素为中心元素,向着两边扩展,一种是以i位置和i+1位置元素为中心,分别向两边扩展。因此对于每个字符i,按照上述两种方式分别求出以当前位置为中心的最长回文字串,然后判断最长是哪个即可。

class Solution {
public:
	string longestPalindrome(string s) {
				int n = s.size();
				if (n == 1)
					return s;
				int ret = 0;
				string ssret;
				for (int i = 0; i < n; i++)
				{
					int j = 1;
					int len1 = 1;

					while (i - j >= 0 && i + j < n && s[i - j] == s[i + j])
					{
						len1 += 2;
						j++;
					}

					j = 0;
					int len2 = 0;
					while (i - j >= 0 && i + 1 + j < n && s[i - j] == s[i + j+1])
					{
						len2+=2;
						j++;
					}
					if (len1 > len2)
					{
						if (ret < len1)
						{
							ssret = s.substr(i - len1 / 2, len1);
							ret = len1;
						}
					}
					else
					{
						if (ret < len2)
						{
							ssret = s.substr(i + 1 - len2 / 2, len2);
							ret = len2;
						}
					}
				}

				return ssret;
			}
};

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值