ICode9

精准搜索请尝试: 精确搜索
首页 > 编程语言> 文章详细

Manacher 算法(马拉车算法)

2022-01-25 18:05:48  阅读:189  来源: 互联网

标签:string int Manacher len 算法 str 回文 mx 拉车


参考博客

该算法可以在时间空间都为O(n),求出最大的回文子串

string longestPalindrome(string s) {
    string str;
    string ans;
    int start=0, end=0;
    str += "$#";
    for (int i = 0; i < s.size(); i++) {//初始化,使用#对字符串每一个间隙都进行填充
        str += s[i];
        str += "#";
    }
    str += "^";//字符串首尾加上#,^不同字符避免越界判定
    int len = str.size();
    int Max_len = -1;//最大的回文长度
    int id;//最右边的回文串的最中间
    int mx = 0;//最右边的回文串的最右界限
    int p[2009] = {};
    for (int i = 1; i < len; i++) {
        if (i < mx) {//在界限内
            p[i] = min(p[2 * id - i], mx - i);
        }
        else {
            p[i] = 1;
        }
        while (str[i - p[i]] == str[i + p[i]]) {//扩大
            p[i]++;
        }
        if (mx < i + p[i]) {//如果不是最右,更新
            id = i;
            mx = i + p[i];
        }
        if (p[i] - 1 > Max_len) {//记录位置
            Max_len = p[i] - 1;
            start = i - p[i]+1;
            end = i + p[i]-1;
        }
    }
    for (int i = start; i <= end; i++) {//截取最大回文串
        if (str[i] != '#') {
            ans += str[i];
        }
    }
    return ans;
}

int main()
{
    cout << longestPalindrome("babad") << endl;//bab
    return 0;
}

 

标签:string,int,Manacher,len,算法,str,回文,mx,拉车
来源: https://www.cnblogs.com/whhh/p/15843880.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有