描述
对于长度为n的一个字符串A(仅包含数字,大小写英文字母),请设计一个高效算法,计算其中最长回文子串的长度。
数据范围: 1≤𝑛≤10001≤n≤1000
要求:空间复杂度 𝑂(1)O(1),时间复杂度 𝑂(𝑛2)O(n2)
进阶: 空间复杂度 𝑂(𝑛)O(n),时间复杂度 𝑂(𝑛)O(n)
示例1
输入:
"ababc"
返回值:
3
说明:
最长的回文子串为"aba"与"bab",长度都为3
#include <vector>
class Solution {
public:
int calcLength(std::string&A, int i, int j)
{
//判断是否为回文,左右字符相等
while(i >=0 && j< A.length() && A[i] == A[j])
{
i--;
j++;
}
return j - i - 1; //返回回文字符串长度
}
/**
* 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可
*
*
* @param A string字符串
* @return int整型
*/
int getLongestPalindrome(string A) {
// write code here
int n = A.length();
int maxlength = 1;
//遍历,以每一个字符为中心
for(int i = 0; i < n-1; i++)
{
//calcLength(A, i, i) 偶数回文子串长度
//calcLength(A, i, i+1) 奇数回文字串长度
maxlength = std::max(maxlength, std::max(calcLength(A, i, i) , calcLength(A, i, i+1)));
}
return maxlength;
}
};