5. 最长回文子串

给定一个字符串 s,找到 s 中最长的回文子串。你可以假设 的最大长度为1000。

示例 1:

输入: "babad"
输出: "bab"
注意: "aba"也是一个有效答案。

示例 2:

输入: "cbbd"
输出: "bb"

解题思路——


1. 暴力解法就不说了,就是遍历所有的子串,然后找最大。

2. 我采用的是马拉车算法,Manacher,可以在O(n)的时间复杂度内解决这个问题。

3. 如果把

p[i] = mx>i?min(p[2*id-i],mx-i):1;改为p[i] = 1;就可以认为是第三种方法,中心搜索法
class Solution {
public:
    string Manacher(string s) {
    //先处理原字符串
    string t = "$#";
    for(int i=0;i p(t.size(),0);
    int id = 0,mx = 0;int resLen=0,resCenter = 0;
    for(int i=1;ii?min(p[2*id-i],mx-i):1;
        while(t[i-p[i]] == t[i+p[i]])
            p[i]++;
        if(mx - i

你可能感兴趣的:(LeetCode)