码迷,mamicode.com
首页 > 编程语言 > 详细

manacher算法

时间:2018-08-15 14:04:45      阅读:152      评论:0      收藏:0      [点我收藏+]

标签:i++   har   void   习题   cpp   char s   for   pre   ==   

模板

void manacher(char s[],int n){
    int pos=0,mx=0;
    for(int i=1;i<=n;i++){
        if(i<mx) p[i]=min(p[(pos<<1)-i],mx-i]);
        else p[i]=1;
        while(s[i+p[i]]==s[i-p[i]]) p[i]++;
        if(i+p[i]>mx) mx=i+p[i],pos=i;
    }
}

习题

manacher算法

标签:i++   har   void   习题   cpp   char s   for   pre   ==   

原文地址:https://www.cnblogs.com/lsq647vsejgfb/p/9480897.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!