马拉车(manacher)算法

————引用博客

跟kmp基本流程相似,求解过程中需要对分析串进行预处理,求解p[i]使其能表示匹配串中回文串的关系

int manacher(string s)
{
    string t="*#";
    for(int i=0;i<s.size();i++){
        t+=s[i];
        t+="#";
    }
    vector<int > p(t.size(),0);
    int mx=0,id=0,str_center=0,str_len=0;
    for(int i=1;i<s.size();++i){
        p[i]=mx>i?min(p[2*id-i],mx-i):1;
        while(t[i+p[i]]==t[i-p[i]])
            ++p[i];
        if(mx<p[i]+i){
            mx=p[i]+i;
            id=i;
        }
        if(str_len<p[i]-1){
            str_len=p[i]-1;
            str_center=i;
        }
    }
    return str_len-1;
}

跟kmp不同的是在进行求解p[i]之前需要对匹配串进行预处理 ,使其扩展为奇数为串避免分支讨论在这里插入图片描述
在此基础上分析出最长回文半径和最长回文子串长度之间的关系:

int maxLength = p[i]-1

其中maxLength表示最长回文子串长度
为方便分析合并杂余讨论项将串下标整体后移一位
在这里插入图片描述
最长回文子串的起始索

int index = (i - p[i])/2
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值