引入

引入

Manachar算法主要是处理字符串中关于回文串的问题的,这没什么好说的。

M

a

n

a

c

h

e

r

Manacher算法

Manacher算法

朴素

求一个字符串中以每个点为中心的最长回文子串,这是

m

a

n

a

c

h

e

r

manacher

manacher 直接解决的问题。

以每个点为中心的回文子串是连续的,它并不像字符串的

b

o

r

d

e

r

border

border ,因此可以二分,于是在不知道

m

a

n

a

c

h

e

r

manacher

manacher 的情况下其实可以用字符串哈希+二分,只不过是

O

(

n

l

o

g

n

)

O(nlogn)

O(nlogn) 的。

但是

m

a

n

a

c

h

e

r

manacher

manacher 可以

O

(

n

)

O(n)

O(n) 算出,因此在有些专门卡

l

o

g

log

log 的题目中

m

a

n

a

c

h

e

r

manacher

manacher 有不可比拟的优越性。

我们不妨设以

i

i

i 为中心的最长回文子串长度为

F

[

i

]

2

+

1

F[i]*2+1

F[i]∗2+1 ,

m

a

n

a

c

h

e

r

manacher

manacher 实际上是利用了一个回文字符串内的

F

[

]

F[]

F[] 的性质。

一个回文字符串,因为它是对称的,因此在仅考虑此字符串的情况下,它的

F

F

F 数组也是对称的,这便是

m

a

n

a

c

h

e

r

manacher

manacher 算法的核心了吧。

因此,我们考虑从左到右依次计算

F

[

i

]

F[i]

F[i] ,当遍历到一个点

i

i

i 时,首先

F

[

i

1

]

F[i-1]

F[i−1] 肯定已经算出来了。

如果

F

[

i

1

]

=

=

0

F[i-1]==0

F[i−1]==0 就直接暴力扩展 i ,否则,如果

F

[

i

2

]

<

F

[

i

1

]

1

F[i-2] < F[i-1]-1

F[i−2]<F[i−1]−1,说明什么呢?

F

[

i

]

=

F

[

i

2

]

F[i]=F[i-2]

F[i]=F[i−2],一定是这样的.

  1. F

    [

    i

    ]

    F[i]

    F[i] 肯定不能小于

    F

    [

    i

    2

    ]

    F[i-2]

    F[i−2] ,因为这个回文子串以

    i

    1

    i-1

    i−1 为对称中心,两边对称的两点,既然其中

    i

    2

    i-2

    i−2 可以扩大到

    F

    [

    i

    2

    ]

    F[i-2]

    F[i−2],且在

    i

    1

    i-1

    i−1 为中心的大回文串内 ,由于对称性,因此

    [

    i

    F

    [

    i

    2

    ]

    ,

    i

    +

    F

    [

    i

    2

    ]

    ]

    [i-F[i-2],i+F[i-2]]

    [i−F[i−2],i+F[i−2]] 范围内也一定是个回文串。

  2. F

    [

    i

    ]

    F[i]

    F[i] 也不能大于

    F

    [

    i

    2

    ]

    F[i-2]

    F[i−2] ,因为以每个点为中心的回文子串是连续的,

    F

    [

    i

    ]

    >

    F

    [

    i

    2

    ]

    F[i]>F[i-2]

    F[i]>F[i−2] 意味着

    F

    [

    i

    ]

    F[i]

    F[i] 可以为

    F

    [

    i

    2

    ]

    +

    1

    F[i-2]+1

    F[i−2]+1,而由于

    F

    [

    i

    2

    ]

    <

    F

    [

    i

    1

    ]

    1

    F[i-2] < F[i-1]-1

    F[i−2]<F[i−1]−1 ,对于

    i

    2

    i-2

    i−2 来说,

    F

    [

    i

    2

    ]

    +

    1

    F[i-2]+1

    F[i−2]+1 仍然在大回文串范围内,因此

    F

    [

    i

    2

    ]

    F[i-2]

    F[i−2] 肯定就不止这个数了。

然后呢,是不是可以继续利用这个大红串呢?我们还可以考虑

F

[

i

3

]

F[i-3]

F[i−3] 是否小于

F

[

i

1

]

2

F[i-1]-2

F[i−1]−2 来决定

F

[

i

+

1

]

F[i+1]

F[i+1] ,考虑

F

[

i

4

]

F[i-4]

F[i−4] 是否小于

F

[

i

1

]

3

F[i-1]-3

F[i−1]−3 来决定

F

[

i

+

2

]

F[i+2]

F[i+2] ……直到超出红框或者:有一个

F

[

i

2

x

]

F

[

i

1

]

1

x

F[i-2-x] ≥ F[i-1]-1-x

F[i−2−x]≥F[i−1]−1−x,这时候,

F

[

i

+

x

]

F[i+x]

F[i+x] 至少能扩大到红框边界吧,因为它的对称点都能扩大到红框边界。然后,再把

F

[

i

+

x

]

F[i+x]

F[i+x] 暴力往外扩。

我们会发现,整个过程中,每次往外扩一定能使前面所有的

i

+

F

[

i

]

i+F[i]

i+F[i] 的最大值变大,因此,它是线性的。

转化

很明显,对于一个回文字符串而言,并不一定中心是一个字符,也有可能是两个相同的字符的中界,即回文串长度为偶数,因此,一般把原串中每两个字符中间添一个没出现过的字符,于是所有的

F

[

i

]

2

+

1

F[i]*2+1

F[i]∗2+1(包括边界的)都会变成

(

F

[

i

]

2

+

1

)

2

+

1

(F[i]*2+1)*2+1

(F[i]∗2+1)∗2+1 ,这样就可以解决长度为偶数的情况。

模板

void Manacher(char *s,int *F,int n) {// 已是转化后的 S
F[1] = 0;
for(int i = 2;i <= n;i ++) {
int j = i;
while(j < i-1+F[i-1] && j+F[i-1-(j-i+1)] < i-1+F[i-1]) F[j] = F[i-1-(j-i+1)],j ++;
F[j] = max(0,i-1+F[i-1] - j);
while(j+F[j] < n && j-F[j] > 1 && s[j+F[j]+1] == s[j-F[j]-1]) F[j] ++;
i = j;
}
return ;
}

Manacher算法讲解——字符串最长回文子串的更多相关文章

  1. manacher算法_求最长回文子串长度

    很好的总结,转自: http://blog.csdn.net/dyx404514/article/details/42061017 总结为:两大情况,三小情况. 两大情况:I. i <= p 1 ...

  2. manacher算法学习(求最长回文子串长度)

    Manacher总结 我的代码 学习:yyb luogu题目模板 xzy的模板 #include<iostream> #include<cstdlib> #include< ...

  3. [hdu 3068] Manacher算法O(n)最长回文子串

    一个不错的讲解:https://github.com/julycoding/The-Art-Of-Programming-By-July/blob/master/ebook/zh/01.05.md # ...

  4. hihoCoder #1032 : 最长回文子串 [ Manacher算法--O(n)回文子串算法 ]

    传送门 #1032 : 最长回文子串 时间限制:1000ms 单点时限:1000ms 内存限制:64MB 描述 小Hi和小Ho是一对好朋友,出生在信息化社会的他们对编程产生了莫大的兴趣,他们约定好互相 ...

  5. Manacher算法:求解最长回文字符串,时间复杂度为O(N)

    原文转载自:http://blog.csdn.net/yzl_rex/article/details/7908259 回文串定义:"回文串"是一个正读和反读都一样的字符串,比如&q ...

  6. Manacher (马拉车) 算法:解决最长回文子串的利器

    最长回文子串 回文串就是原串和反转字符串相同的字符串.比如 aba,acca.前一个是奇数长度的回文串,后一个是偶数长度的回文串. 最长回文子串就是一个字符串的所有子串中,是回文串且长度最长的子串. ...

  7. 马拉车算法,mannacher查找最长回文子串

    作用: 在线性时间内找到一个字符串的最大回文子串 原理: 奇偶变换:为处理字符串方便,现将给定的任意字符串进行处理,使所有可能的奇数/偶数长度的回文子串都转换成了奇数长度. 具体就是在每个字符的两边都 ...

  8. Manacher模板( 线性求最长回文子串 )

    模板 #include<stdio.h> #include<string.h> #include<algorithm> #include<map> us ...

  9. Manacher算法--O(n)回文子串算法

    转自:http://blog.csdn.net/ggggiqnypgjg/article/details/6645824 O(n)回文子串算法 注:转载的这篇文章,我发现下面那个源代码有点bug... ...

随机推荐

  1. C语言学习之我见-strcmp()字符串比较函数

    strcmp()函数,用于两个字符串的比较. (1)函数原型 int strcmp(const char *_Str1,const char *_Str2); (2)头文件 string.h (3)功 ...

  2. web文本划线的极简实现

    开篇 文本划线是目前逐渐流行的一个功能,不管你是小说阅读网站,还是卖教程的的网站,一般都会有记笔记或者评论的功能,传统的做法都是在文章底部加一个评论区,优点是简单,统一,缺点是不方便对文章的某一段或一 ...

  3. Mybatis-Plus介绍

    Mybatis-Plus介绍 Mybatis-Plus概念 Mybatis-Plus介绍 官网https://mybatis-plus/或https://mp.baomidou.com/ mybati ...

  4. Centos8安装NextCloud记录

    今天在网上学习了这个Nextcloud 网盘的搭建,被折磨的快崩溃了.始终是找不到答案,我在网上查了2天的资料 还是没有找到答案,今天这里总结一下安装的下面的总结: 原文出处在官网:CentOS 8 ...

  5. SpringBoot接口 - 如何优雅的写Controller并统一异常处理?

    SpringBoot接口如何对异常进行统一封装,并统一返回呢?以上文的参数校验为例,如何优雅的将参数校验的错误信息统一处理并封装返回呢?@pdai 为什么要优雅的处理异常 如果我们不统一的处理异常,经 ...

  6. e.printStackTrace() 原理的分析

    e.printStackTrace(); 先查看下源码 如图片中1所示,使用的是 PrintStreamOrWriter public void printStackTrace() { printSt ...

  7. nexus 配置文件到本地maven本地仓库 失败

    Failed to execute goal org.apache.maven.plugins:maven-deploy-plugin:2.7:deploy (default-deploy) on p ...

  8. APISpace 让你快速获取笑话大全

    最近公司项目有一个随机展示各类笑话的小需求,想着如果用现成的API就可以大大提高开发效率,在网上的API商店搜索了一番,发现了 APISpace,它里面的 笑话大全API 非常符合我的开发需求.   ...

  9. APISpace 全球快递物流查询API接口 免费好用

    前言   随着我国电子商务的迅猛发展,物流行业也开始突飞猛进,人们的日常生活越来越离不开快递服务,查快递.寄快递的需求越来越大,随之而来,常用快递接口的需求也越来越大. 全国快递查询接口,支持各大快递 ...

  10. identity server4 授权成功页面跳转时遇到错误:Exception: Correlation failed. Unknown location的解决方法

    一.异常信息描述 错误信息,看到这个页面是否耳熟能详担又不知道怎么解决 ,坑死个人不偿命,,,,,,,, 二.处理方法 1.在web项目中增加类SameSiteCookiesServiceCollec ...