[字符串算法]Manacher
1.前置知识
回文子串 回文的子串
最长回文子串 字符串中最长的回文子串
回文半径 设以\(i\)为中心的最大回文子串的长度为\(n\),则这个字符串第\(i\)位的回文半径为\((n+1)/2\)
2.算法流程
2.1 预处理
在处理回文子串(马拉车算法适用)的问题时,一般需要求出每一位的回文半径
经常做字符串题目的同学都知道,在处理这种问题时,最大的阻碍一般就是字符串长度的奇偶性以及边界
不难想到,我们可以在字符串的首尾分别插入一个字符来解决边界问题
也不难想到,我们可以在每一个字符的首尾都添加一个字符(包括第\(1\)个和最后一个)
由此,我们可以得到一个新字符串。
这里举一个例子,
原字符串s:ababa
进行完操作1(首尾标记)的字符串 s1: @ababa@
进行完操作2(字符插入)的字符串 s2: @#a#b#a#b#a#@
根据流程不难得出代码:
cin>>a;//原串
int len=strlen(a);
int k=0;
s[0]='$';
s[1]='#';
k++;
for(int i=0;i<=len;i++)
{
s[++k]=a[i];
s[++k]='#';
}
n=k;
是的是的我懂 你们想要照搬 但是看到我那不顺眼的++k急了
这个千万不能改,是先自增在标记!!
2.2 加速盒子(核心部分)
我超,盒!
是的是的学过扩展KMP算法的同学们应该都熟悉的乐子东西
所以接下来就让我演示一下这东西
本质上是一个分类讨论 分三种情况:
2.2.1 在盒内(整体)
如图,

蓝色段全体在盒子内,这个时候直接用对称点的就可以了
举例:

所以这是显而易见的
2.2.2 在盒内(部分)
如图,

蓝色段有一部分出去了,所以从\(r\)开始暴力
2.2.3 在盒外(全部)
不配图了,这个是显而易见的,两端都不在盒子内,因此只能暴力求解
2.2.4 更新(upd)
求出\(d[i]\)后,如果右端有最大值,那么更新盒位置
2.2.5 代码
依次逻辑则可以写出代码
int manacher(char s[],int n)
{
d[1]=1;
for(int i=2,l,r=1;i<=n;i++)
{
if(l<=r)
{
d[i]=min(d[r-i+l],r-i+1);
}
while(s[i-d[i]]==s[i+d[i]])
{
d[i]++;
}
if(i+d[i]-1>r)
{
l=i-d[i]+1;
r=i+d[i]-1;
}
}
}
3.例题
终于学完了
例题可以尝试去做一下A. 【例题1】不交回文串
提示:前缀和+Manacher
这里就不放代码了,自己回家好好思考一下
拜!
[字符串算法]Manacher的更多相关文章
- ACM -- 算法小结(八)字符串算法之Manacher算法
字符串算法 -- Manacher算法 首先介绍基础入门知识,以下这部分来着一贴吧,由于是很久之前看的,最近才整理一下,发现没有保存链接,请原创楼主见谅. //首先:大家都知道什么叫回文串吧,这个算法 ...
- 【字符串算法2】浅谈Manacher算法
[字符串算法1] 字符串Hash(优雅的暴力) [字符串算法2]Manacher算法 [字符串算法3]KMP算法 这里将讲述 字符串算法2:Manacher算法 问题:给出字符串S(限制见后)求出最 ...
- 【字符串算法1】 再谈字符串Hash(优雅的暴力)
[字符串算法1] 字符串Hash(优雅的暴力) [字符串算法2]Manacher算法 [字符串算法3]KMP算法 这里将讲述 [字符串算法1] 字符串Hash 老版原文: RK哈希(Rabin_Ka ...
- 【字符串算法3】浅谈KMP算法
[字符串算法1] 字符串Hash(优雅的暴力) [字符串算法2]Manacher算法 [字符串算法3]KMP算法 这里将讲述 [字符串算法3]KMP算法 Part1 理解KMP的精髓和思想 其实KM ...
- 经典算法 Manacher算法详解
内容: 1.原始问题 =>O(N^2) 2.Manacher算法 =>O(N) 1.原始问题 Manacher算法是由题目“求字符串中长回文子串的长度”而来.比如 abcdcb 的 ...
- 浅谈算法——Manacher
字符串算法在各大高级比赛中均有用到,所以,学习好字符串算法对我们而言十分重要.那么,今天我们就给大家介绍一个快速求回文串的算法,Manacher算法,我们也习惯性叫它马拉车算法. 一.引入 首先我们要 ...
- boost字符串算法
boost::algorithm简介 2007-12-08 16:59 boost::algorithm提供了很多字符串算法,包括: 大小写转换: 去除无效字符: 谓词: 查找: 删除/替换: 切割: ...
- 字符串算法之 AC自己主动机
近期一直在学习字符串之类的算法,感觉BF算法,尽管非常easy理解,可是easy超时,全部就想学习其它的一些字符串算法来提高一下,近期学习了一下AC自己主动机.尽管感觉有所收获,可是还是有些朦胧的感觉 ...
- 【字符串】manacher算法
Definition 定义一个回文串为从字符串两侧向中心扫描时,左右指针指向得字符始终相同的字符串. 使用manacher算法可以在线性时间内求解出一个字符串的最长回文子串. Solution 考虑回 ...
- 【字符串】 manacher算法
Algorithm Task 给定一个字符串,求其最长回文子串 Limitations 要求时空复杂度均为线性且与字符集大小无关. Solution 考虑枚举回文串的对称轴,将其对应的最长回文子串长度 ...
随机推荐
- Win32汇编学习笔记01.环境配置
Win32汇编学习笔记01.环境配置-C/C++基础-断点社区-专业的老牌游戏安全技术交流社区 - BpSend.net 环境配置 masm32下载 官网:http://www.masm32.com/ ...
- L1-4、如何写出清晰有目标的 Prompt
-- 写给想真正掌握 Prompt 写作逻辑的人 为什么要"清晰.有目标"? 在用 AI 时,很多人会碰到这些情况: 明明下达了指令,但 AI 总是理解错方向? 想让 AI 写一段 ...
- Scrum进入疲惫期?三点帮你走出困境
<敏捷软件开发>中提到: "Scrum 可以帮助团队更好地应对变化和不确定性,以及更快地响应客户需求.通过持续的反馈和改进,Scrum 可以提高团队的适应性和灵活性." ...
- maixpy 常用API整理
2.openmvAPI整理 2.1 cmath - 复数的数学函数 cos cmath.cos(z) 返回z的余弦. exp cmath.exp(z) 返回z的指数. log cmath.log(z) ...
- JuiceFS介绍
简单介绍 JuiceFS 是一款面向云原生设计的高性能分布式文件系统,在 Apache 2.0 开源协议下发布.提供完备的 POSIX 兼容性,可将几乎所有对象存储接入本地作为海量本地磁盘使用,亦可同 ...
- 使用Oracle数据库的递归查询语句生成菜单树
SQL 格式 SELECT * FROM TABLE WHERE [...结果过滤语句] START WITH [...递归开始条件] CONNECT BY PRIOR [...递归执行条件] 查询所 ...
- 激活数据价值,探究DataOps下的数据架构及其实践丨DTVision开发治理篇
据中国信通院发布,2012年到2021年10年间,我国数字经济规模由12万亿元增长到45.5万亿元,在整个GDP中的比重由21.6%提升至39.8%.顺应时代发展新趋势,"数据"成 ...
- UFT 模拟鼠标(包括fireEvent) & 键盘操作
1. 鼠标 2. 键盘 3. UFT FireEvent 实现多样JS 操作
- springBoot启动 Error running Application. Command line is too long. Shorten the command line via JAR manifest or via a classpath file and rerun.
1. 打开SpringBoot启动配置 2.选择shorten command line 3.apply保存就行了
- FastAPI如何玩转安全防护,让黑客望而却步?
扫描二维码 关注或者微信搜一搜:编程智域 前端至全栈交流与成长 发现1000+提升效率与开发的AI工具和实用程序:https://tools.cmdragon.cn/ 1. FastAPI安全基础架构 ...