Manacher算法是求回文串最高效的算法,能在线性时间内求出以每一个字符为中心的最长回文串。

 
首先,我们都能想出$O(N^2)$求出每一个字符为中心的最长回文串的算法。那么我们考虑这样一种情况。
如果一个回文串内包含了回文串。那么是否可以减少重复的计算。
比如
abaaba  这个字符串,要求他的最长回文串,首先我们应区分开奇数串和偶数串,考虑给每个字符中间加上一个之前从来没有出现过的字符,通常采用‘#’。
那么上面那个字符串就变成了
#a#b#a#a#b#a#
 
这时候就免除了对奇数串还是偶数串的分类讨论。即所有的回文串都是奇数串。
再思考这样一个情况,如果我们已经求出了第六个字符的最长回文串和第三个字符的最长回文串,那么第9个字符串的最长回文串长度显然等于第三个字符的最长回文串长度。即如果一个字符串是回文的,那么这个字符串倒转过来显然仍然是回文串。这就使Manacher算法变得很高效。
 
代码实现:
 
namespace solution{
      void manacher(){
            if(!((s[0]>='a'&&s[0]<='z')||(s[0]>='A'&&s[0]<='Z')))exit(0);
            LEN=strlen(s);
            t[0]='!';
            up(i,1,LEN*2){
                  t[i]='#';
                  t[i+1]=s[i/2];
                  i++;
            }
            t[2*LEN+1]='#';
            t[2*LEN+2]='$';
            LEN=2*LEN+1;
            rightt=ans=pos=0;
            up(i,1,LEN){
                  if(rightt>i)len[i]=min(rightt-i,len[2*pos-i]);
                  else        len[i]=1;
                  while(t[i-len[i]]==t[i+len[i]])len[i]++;
                  if(len[i]+i>rightt){
                        rightt=len[i]+i;
                        pos=i;
                  }
                  ans=max(ans,len[i]);
            }
            printf("%d\n",ans-1);
      }
}

首先把字符串转变,同时在最后一个字符处加上不同于所有字符的字符,防止越界。然后下面就是manacher算法的流程。不再多说。

Manacher算法的更多相关文章

  1. HDU3068 回文串 Manacher算法

    好久没有刷题了,虽然参加过ACM,但是始终没有融会贯通,没有学个彻底.我干啥都是半吊子,一瓶子不满半瓶子晃荡. 就连简单的Manacher算法我也没有刷过,常常为岁月蹉跎而感到后悔. 问题描述 给定一 ...

  2. manacher算法专题

    一.模板 算法解析:http://www.felix021.com/blog/read.php?2040 *主要用来解决一个字符串中最长回文串的长度,在O(n)时间内,线性复杂度下,求出以每个字符串为 ...

  3. lintcode最长回文子串(Manacher算法)

    题目来自lintcode, 链接:http://www.lintcode.com/zh-cn/problem/longest-palindromic-substring/ 最长回文子串 给出一个字符串 ...

  4. 1089 最长回文子串 V2(Manacher算法)

    1089 最长回文子串 V2(Manacher算法) 基准时间限制:1 秒 空间限制:131072 KB 分值: 0 难度:基础题  收藏  关注 回文串是指aba.abba.cccbccc.aaaa ...

  5. 51nod1089(最长回文子串之manacher算法)

    题目链接: https://www.51nod.com/onlineJudge/questionCode.html#!problemId=1089 题意:中文题诶~ 思路: 我前面做的那道回文子串的题 ...

  6. LeetCode 5 Longest Palindromic Substring manacher算法,最长回文子序列,string.substr(start,len) 难度:2

    https://leetcode.com/problems/longest-palindromic-substring/ manacher算法相关:http://blog.csdn.net/ywhor ...

  7. 求最长回文子串:Manacher算法

    主要学习自:http://articles.leetcode.com/2011/11/longest-palindromic-substring-part-ii.html 问题描述:回文字符串就是左右 ...

  8. 【转】最长回文子串的O(n)的Manacher算法

    Manacher算法 首先:大家都知道什么叫回文串吧,这个算法要解决的就是一个字符串中最长的回文子串有多长.这个算法可以在O(n)的时间复杂度内既线性时间复杂度的情况下,求出以每个字符为中心的最长回文 ...

  9. 字符串匹配--manacher算法模板

    manacher算法主要是处理字符串中关于回文串的问题的,它可以在 O(n) 的时间处理出以字符串中每一个字符为中心的回文串半径,由于将原字符串处理成两倍长度的新串,在每两个字符之间加入一个特定的特殊 ...

随机推荐

  1. 【python游戏编程之旅】第八篇---pygame游戏开发常用数据结构

    本系列博客介绍以python+pygame库进行小游戏的开发.有写的不对之处还望各位海涵. 上一个博客我们一起学习了pygame中冲突检测技术:http://www.cnblogs.com/msxh/ ...

  2. [译]用AngularJS构建大型ASP.NET单页应用(三)

    原文地址:http://www.codeproject.com/Articles/808213/Developing-a-Large-Scale-Application-with-a-Single A ...

  3. Google最新截屏案例详解

    Google从Android 5.0 开始,给出了截屏案例ScreenCapture,在同版本的examples的Media类别中可以找到.给需要开发手机或平板截屏应用的小伙伴提供了非常有意义的参考资 ...

  4. Sentinel-Redis高可用方案(二):主从切换

    Redis 2.8版开始正式提供名为Sentinel的主从切换方案,Sentinel用于管理多个Redis服务器实例,主要负责三个方面的任务:     1. 监控(Monitoring): Senti ...

  5. leetcode-Warm Up Contest-Aug.21

    leetcode   地址: https://leetcode.com/contest/detail/1 (1)-- Lexicographical Numbers Given an integer  ...

  6. Android出现错误后改正后仍显示错误

    今天编Android的时候,layout.xml出现了错误,改正后仍显示错误.试了很多方法. 后来,将原来的复制并删掉,然后再粘贴上去就可以了.

  7. IntelliJ idea的使用

    1.快捷键 2.插件集成 附录:参考资料

  8. Ajax深入学习

    1.ajax如何减轻服务器的负担的? 2.如何合理的使用ajax? 3.一个页面一进来等文档加载完毕:走ajax请求去了?    用户体验真的好吗?

  9. Windows下Php安装mongodb扩展失败

    查看php版本 下载对应的mongodb插件 将php_mongo.dll文件复制到php安装目录下的ext下 重启apache Apache –k restart 浏览器php.info( )测试 ...

  10. XML与 HTML

    XML是E4X中定义的一个重要的新类型,侧重于如何结构化描述信息,用它来表现XML结构中任何独立的部分,是一种用于标记电子文件使其具有结构性的标记语言. XML语言被设计用来描述数据,它的焦点是数据的 ...