【笔记】Manacher

news/2026/1/14 17:42:34/文章来源:https://www.cnblogs.com/Seqfrel/p/19343495

Luogu P3805 【模板】manacher

解决问题:字符串中最长回文子串。

解决方法:求出字符串中每个字符作为回文串中心时最长回文串长度。

朴素做法,对于每个字符向后枚举比较,时间复杂度 \(O(n^2)\)

Manacher 算法提供一种优化策略,使得相同的回文串不被重复计算,时间复杂度可达 \(O(n)\)

思想:

偶数长度的回文串,其中心在两个字符之间,因此我们可以在两两字符之间插入一个标识符,使得原串中所有回文串长都是奇数,方便对每个字符进行操作;同时在边界放上未在串和标识符中出现的字符,回文串判断到边界时一定不相等,自动退出。

对于一个当前已求出的回文串,其两侧对称,则若单看该回文串中的字符,两侧每个字符作回文中心的最长回文串长也相同。所以这部分可以不用重复计算,直接赋值即可。之后再去考虑回文串外的相等情况,延伸以该字符做中心的回文串。

维护一个数组 \(len\)\(len_i\) 表示以当前字符作为回文中心的最长回文串长度,再维护两个变量 \(mid\)\(r\),表示当前右边界最靠右的回文串中心和右边界。对于一个字符,如果其在右边界内,则其作回文中心的最长回文串长至少为与其对称字符的值。然后再去往右判断,延伸其串长。延伸后用更右的边界更新 \(mid\)\(r\)

答案需要 \(-1\),因为中间有插板。

#include<iostream>
#include<cstdio>
using namespace std;
const int N=1.1e7+10;
int n,tot=1;
int len[N*2];
char c[N],s[N*2];
int main(){scanf("%d",&n);scanf("%s",c+1);s[0]='^';s[1]='#';for(int i=1;i<=n;i++){s[++tot]=c[i];s[++tot]='#';}int mid=0,r=0,ans=0;for(int i=1;i<=tot;i++){if(i<=r) len[i]=min(len[2*mid-i],r-i+1);while(s[i-len[i]]==s[i+len[i]]) len[i]++;if(len[i]+i-1>r){r=len[i]+i-1;mid=i;}ans=max(ans,len[i]);}printf("%d\n",ans-1);return 0;
}

时间复杂度的证明:如果串长不到右边界 \(r\),则 while 循环不会执行。因此 while 循环最多执行 \(tot\) 遍,仍为线性复杂度。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/1004773.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

C51_74HC165并口转串口

文章目录一、74HC165二、74HC165使用   1、引脚   2、工作流程   3、原理图三、实例代码一、74HC165 74HC165 是 8 位并行输入串行输出移位寄存器&#xff0c;它是一款高速 CMOS 器件&#xff0c;遵循 JEDEC 标准。    74HC165 是一款8 位并行输入 - 串行输出的移位寄存…

八上期中考游记

真是失败的人生。 为了 CSP 花费了好多时间,但是变成了最差的一年,怎么回事呢? 语文 \(104\),炸飞了。 数学 \(148\) 挂到 \(140\),年段 rk \(1 \to 8\),这波真是失败的人生。 英语 \(130\),卷子好难,炸杠。 物…

application.properties

[Spring Boot] Java开发实战&#xff1a;Spring Boot应用详解 引言 Spring Boot是Java开发中一个非常重要的框架&#xff0c;它简化了Spring应用的初始搭建和开发过程。作为一年经验的Java开发者&#xff0c;我们需要学习它是因为现在大部分企业级项目都在使用Spring Boot。在实…

电动汽车永磁同步电机的电磁设计与最优控制探索

永磁同步电机具有效率高、功率密度大、鲁棒性强以及调速范围广等优点&#xff0c;被广泛应用于家用电器、航空航天、轨道交通与电动汽车等领域&#xff0c;是当前电机领域研究和应用热点。 本文以电动汽车驱动用永磁同步电机电磁设计和最优控制为研究内容&#xff0c;对永磁同步…

【题解】Luogu B4185 [中山市赛 2024/科大国创杯小学组 2023] 倍数子串/子串

明明是很容易的题模拟赛却没注意到。 数学、模拟 题意 略。 思路 不妨从 \(5\) 下手。一数仅当最后一位是 \(0\) 或 \(5\) 时,该数才是 \(5\) 的倍数。因此如果第 \(i\) 位是 \(0\) 或 \(5\),所有最后一位是 \(5\) 的…

智能客服机器人产品设计

目录完整的导购 FSM(有限状态机)设计 — 可直接交付给产品/架构/开发2. 状态表(每个状态的定义、触发条件、允许动作、默认 CTA、工具调用)GREETINGNEED_DISCOVERYPRODUCT_MATCHRECOMMENDATIONCOMPARISONOBJECTION…

JavaScript 异常原因(Error Cause):实现分布式系统错误链追踪的序列化与反序列化

在现代复杂的分布式系统中&#xff0c;服务的协同工作是常态。然而&#xff0c;服务的相互依赖也带来了巨大的挑战&#xff0c;尤其是在错误处理和故障诊断方面。当一个请求流经多个微服务时&#xff0c;任何一个环节的失败都可能导致整个业务流程中断。要高效地定位问题的根源…

毕业论文任务书范文推荐:7大平台+AI修改工具

毕业论文任务书范文推荐&#xff1a;7大平台AI修改工具 工具名称 核心功能 生成速度 适用场景 独特优势 aibiye 论文初稿生成 20-30分钟 全学科通用 自动插入图表公式 aicheck 初稿查重 20-30分钟 急需查重场景 独创降AIGC算法 askpaper 初稿生成 20-30分钟 …

天远多头借贷行业风险版API接口调用代码流程、接入方法以及应用场景

一、精细化风控时代的“多头”计量工具 在互金与银行信贷业务中&#xff0c;“多头借贷”&#xff08;Multi-Lending&#xff09;往往是借款人资金链断裂的前兆。然而&#xff0c;传统的借贷次数统计已难以满足精细化风控的需求——借款人是在银行申请房贷&#xff0c;还是在夜…

Python字典与集合:解锁高效数据处理的关键,90%的人没吃透这几点

Python字典与集合:解锁高效数据处理的关键,90%的人没吃透这几点 在Python数据结构家族中,字典(dict)和集合(set)是隐藏的“性能王者”。相比于列表和元组,它们在查找、添加、删除操作上的效率呈指数级提升,尤…

详细介绍:完整事务性能瓶颈分析案例:支付系统事务雪崩优化

pre { white-space: pre !important; word-wrap: normal !important; overflow-x: auto !important; display: block !important; font-family: "Consolas", "Monaco", "Courier New", …

计算机论文选题推荐:9大AI+热门方向排名

计算机论文选题推荐&#xff1a;9大AI热门方向排名 &#xfffd;&#xfffd; 9大AI选题方向速览 排名 选题方向 创新指数 研究热度 就业前景 1 大模型微调与应用 ⭐⭐⭐⭐⭐ &#xfffd;&#xfffd;&#xfffd;&#xfffd;&#xfffd;&#xfffd;&#xfffd;&…

JavaScript 记录(Records)与 元组(Tuples):实现堆内存中不可变复合数据结构的内存布局

JavaScript作为一门动态、弱类型的语言&#xff0c;其灵活性在带来了开发效率的同时&#xff0c;也引入了管理复杂状态和确保数据完整性的挑战。长期以来&#xff0c;JavaScript开发者在处理不可变数据结构时&#xff0c;不得不依赖于浅层冻结&#xff08;如Object.freeze()&am…

虚函数虚表

一、基本原理1.虚函数&#xff1a;用virtual关键字生声明的函数&#xff0c;允许派生类重写2.虚表&#xff1a;每个包含虚函数的类&#xff08;或其派生类&#xff09;会有一个全局唯一的虚表&#xff0c;存储该类所有虚函数的地址3.虚指针&#xff08;vptr&#xff09;&#x…

5 分钟快速入门 Github Actions

GitHub Actions 是 GitHub 官方提供的 CI/CD 解决方案&#xff0c;它内置于 GitHub 平台&#xff0c;用于自动化你的软件构建、测试和部署工作流。&#x1f680; 快速入门 GitHub Actions&#xff1a;自动化你的开发流程 核心概念&#xff1a;理解 Actions 的基石 在开始编写配…

线程并发编程,同步与互斥机制

线程 概念 线程是一个轻量级的进程&#xff0c;为了提高系统的性能引入线程。 线程和进程都参与统一的调度。 在同一个进程中可以创建多个线程&#xff0c;并且共享进程资源。 进程和线程区别(面试题) 相同点&#xff1a;都为操作系统提供了并发执行的能力 不同点&#xff1a; …

Python列表与元组:搞懂这3个核心差异,再也不纠结用哪个

Python 列表与元组:搞懂这 3 个核心差异,再也不纠结用哪个 Python列表与元组:搞懂这3个核心差异,再也不纠结用哪个 在Python编程的世界里,数据结构是构建一切的基石。而列表(list)和元组(tuple),作为Python中…

MQ消息队列相关知识与对比

一、MQ相关的概念 1.1 什么是MQ? MQ&#xff0c;即Message Queue&#xff08;消息队列&#xff09;&#xff0c;是一种基于“生产者-消费者”模式的分布式通信中间件。从字面意思上看就个 FIFO 先入先出的队列&#xff0c;只不过队列中存放的内容是 message 而已&#xff0c…

完整教程:PPT导出为图片的格式选择:JPG与PNG的区别

完整教程:PPT导出为图片的格式选择:JPG与PNG的区别pre { white-space: pre !important; word-wrap: normal !important; overflow-x: auto !important; display: block !important; font-family: "Consolas&quo…

不能头脑简单地搞“凡是”:凡是偶数2n(n的变域是N)必∈N

不能头脑简单地搞“凡是”&#xff1a;凡是偶数2n&#xff08;n的变域是N&#xff09;必∈N黄小宁设一游击队有无穷多个队员&#xff0c;队中各人都配有一枪。各枪都有枪号&#xff0c;将配有 n 号枪的人记为 n 号人&#xff0c;队中枪与人已一一配对&#xff1a; n 号人↔n 号…