Manacher算法讲解——字符串最长回文子串
引
入
引入
引入
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],一定是这样的.
- 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]] 范围内也一定是个回文串。
- 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算法讲解——字符串最长回文子串的更多相关文章
- manacher算法_求最长回文子串长度
很好的总结,转自: http://blog.csdn.net/dyx404514/article/details/42061017 总结为:两大情况,三小情况. 两大情况:I. i <= p 1 ...
- manacher算法学习(求最长回文子串长度)
Manacher总结 我的代码 学习:yyb luogu题目模板 xzy的模板 #include<iostream> #include<cstdlib> #include< ...
- [hdu 3068] Manacher算法O(n)最长回文子串
一个不错的讲解:https://github.com/julycoding/The-Art-Of-Programming-By-July/blob/master/ebook/zh/01.05.md # ...
- hihoCoder #1032 : 最长回文子串 [ Manacher算法--O(n)回文子串算法 ]
传送门 #1032 : 最长回文子串 时间限制:1000ms 单点时限:1000ms 内存限制:64MB 描述 小Hi和小Ho是一对好朋友,出生在信息化社会的他们对编程产生了莫大的兴趣,他们约定好互相 ...
- Manacher算法:求解最长回文字符串,时间复杂度为O(N)
原文转载自:http://blog.csdn.net/yzl_rex/article/details/7908259 回文串定义:"回文串"是一个正读和反读都一样的字符串,比如&q ...
- Manacher (马拉车) 算法:解决最长回文子串的利器
最长回文子串 回文串就是原串和反转字符串相同的字符串.比如 aba,acca.前一个是奇数长度的回文串,后一个是偶数长度的回文串. 最长回文子串就是一个字符串的所有子串中,是回文串且长度最长的子串. ...
- 马拉车算法,mannacher查找最长回文子串
作用: 在线性时间内找到一个字符串的最大回文子串 原理: 奇偶变换:为处理字符串方便,现将给定的任意字符串进行处理,使所有可能的奇数/偶数长度的回文子串都转换成了奇数长度. 具体就是在每个字符的两边都 ...
- Manacher模板( 线性求最长回文子串 )
模板 #include<stdio.h> #include<string.h> #include<algorithm> #include<map> us ...
- Manacher算法--O(n)回文子串算法
转自:http://blog.csdn.net/ggggiqnypgjg/article/details/6645824 O(n)回文子串算法 注:转载的这篇文章,我发现下面那个源代码有点bug... ...
随机推荐
- python求最大公约数和最小公倍数
1 def gcd(x,y): 2 while(y): 3 t=x%y 4 x=y 5 y=t 6 #print("最小公倍数是:",x*y/x)#最小公倍数是两数之积除以最大公约 ...
- 干货合集│最好用的 python 库都在这
一.分词 - jieba 优秀的中文分词库,依靠中文词库,利用词库确定汉子之间关联的概率,形成分词结果 import jieba word = '伟大的中华人民共和国' jieba.cut(word) ...
- 【NOIP2017 提高组正式赛】列队 题解
题目大意 有一个 \(n\times m\) 的方阵,每次有 \((x,y)\) 离开,离开后有两个命令 向左看齐.这时第一列保持不动,所有学生向左填补空缺.这条指令之后,空位在第 \(x\) 行第 ...
- Wireshark学习笔记(二)取证分析案例详解
@ 目录 练习一:分析用户FTP操作 练习二:邮件读取 练习三:有人在摸鱼? 练习一:分析用户FTP操作 已知抓包文件中包含了用户登录FTP服务器并进行交互的一个过程,你能否通过wireshark分析 ...
- Kubernetes-23:详解如何将CPU Manager做到游刃有余
k8s中为什么要用CPU Manager? 默认情况下,kubelet 使用CFS配额来执行 Pod 的 CPU 约束.Kubernetes的Node节点会运行多个Pod,其中会有部分的Pod属于CP ...
- SAP APO-供需匹配
供需匹配包含主要功能"匹配能力"(CTM)和一个用于分配库存的附加功能. 在高级计划和优化中,SDM组件为这些应用程序提供跨工厂供应策略- 生产计划和详细计划(PP / DS) 供 ...
- SAP 时区转换
DATA:l_tzone TYPE tzonref-tzone. "TIME ZONE DATA:l_timesp TYPE tzonref-tstamps."TIME ...
- WPF开发随笔收录-本地日志LogUtil类
一.前言 生活中的日志是记录你生活的点点滴滴,让它把你内心的世界表露出来,更好的诠释自己的内心世界.而在开发者眼中的日志是我们排除问题的第一手资料,项目中的程序上线之后,一旦发生异常,第一件事就是先去 ...
- FTP安装及使用
通过网络传输数据的手段 1. ssh 2. http 3. nfs 4. rsync 5. ftp 6. samba ftp的简介: 1. ftp是应用层协议,是基于TCP 2. 使用21端口 FTP ...
- 论文解读(GCC)《Efficient Graph Convolution for Joint Node RepresentationLearning and Clustering》
论文信息 论文标题:Efficient Graph Convolution for Joint Node RepresentationLearning and Clustering论文作者:Chaki ...