洛谷 P4555 [国家集训队]最长双回文串
链接:
题意:
在字符串 \(S\) 中找出两个相邻非空回文串,并使它们长度之和最大。
分析:
直接使用马拉车算法求出每个点扩展的回文串。如果枚举两个回文串显然会超时,我们考虑切割一个长串,即枚举切割点,只需枚举每个 \(\#\) 即可,但为了保证两个串都非空,所以最左和最右的 \(\#\) 不能枚举。然后我们需要找到最靠左的回文串中心 \(L\) 使得该回文串包括该点,以及最靠右的回文串中心 \(R\) 使得该回文串包括该点,发现两个回文串长度之和就是 \(R-L\)。同时我们发现当切割点向右移动,\(L\) 的位置是单调增的,当切割点向左移动,\(R\) 的位置是单调减的。所以我们可以双指针维护出每个切割点位置对应的 \(L\) 和 \(R\)。于是就做完了。
代码:
#include<bits/stdc++.h>
using namespace std;
#define int long long
const int N=2e5+5;
string t="@#";int n;
inline void gett(){
	char c=getchar();
	while(c>'z'||c<'a')c=getchar();
	while(c>='a'&&c<='z')t+=c,t+="#",c=getchar();
	n=t.length();
}
int hm[N],mr,mid;
inline void match(){
	for(int i=1;i<n;i++){
		hm[i]=(mr>i)?min(hm[(mid<<1)-i],mr-i):1;
		while(t[i+hm[i]]==t[i-hm[i]])hm[i]++;
		if(i+hm[i]>mr)mr=i+hm[i],mid=i;
	}
}
int ans,now;
int l[N],r[N];
signed main(){
	gett();
	match();
	now=1;
	for(int i=1;i<n;i++){
		while(i>now+hm[now]-1)now++;
		l[i]=now;//最靠左的回文串中心L
	}
	now=n;
	for(int i=n-1;i>=1;i--){
		while(i<now-hm[now]+1)now--;
		r[i]=now;//最靠右的回文串中心R
	}
	for(int i=3;i<n-2;i+=2)
		ans=max(r[i]-l[i],ans);
	cout<<ans;
	return 0;
}
洛谷 P4555 [国家集训队]最长双回文串的更多相关文章
- 洛谷 P4555 [国家集训队]最长双回文串 解题报告
		P4555 [国家集训队]最长双回文串 题目描述 顺序和逆序读起来完全一样的串叫做回文串.比如acbca是回文串,而abc不是(abc的顺序为abc,逆序为cba,不相同). 输入长度为\(n\)的串 ... 
- 洛谷 P4555 [国家集训队]最长双回文串(Manacher)
		题目链接:https://www.luogu.com.cn/problem/P4555 首先明白两个回文串,那么要使两个回文串成立,那么我们只能把$'#'$作为中间节点. 然后我们跑一边Manache ... 
- 洛谷P4555 [国家集训队]最长双回文串(manacher 线段树)
		题意 题目链接 Sol 我的做法比较naive..首先manacher预处理出以每个位置为中心的回文串的长度.然后枚举一个中间位置,现在要考虑的就是能覆盖到i - 1的回文串中 中心最靠左的,和能覆盖 ... 
- 【洛谷】P4555 [国家集训队]最长双回文串
		P4555 [国家集训队]最长双回文串 题源:https://www.luogu.com.cn/problem/P4555 原理:Manacher 还真比KMP好理解 解决最长回文串问题 转化为长度为 ... 
- P4555 [国家集训队]最长双回文串
		P4555 [国家集训队]最长双回文串 manacher 用manacher在处理时顺便把以某点开头/结尾的最长回文串的长度也处理掉. 然后枚举. #include<iostream> # ... 
- Manacher || P4555 [国家集训队]最长双回文串 || BZOJ 2565: 最长双回文串
		题面:P4555 [国家集训队]最长双回文串 题解:就.就考察马拉车的理解 在原始马拉车的基础上多维护个P[i].Q[i]数组,分别表示以i结尾最长回文子串的长度和以i开头的最长回文子串的长度 然后就 ... 
- P4555 [国家集训队]最长双回文串(回文树)
		题目描述 顺序和逆序读起来完全一样的串叫做回文串.比如acbca是回文串,而abc不是(abc的顺序为abc,逆序为cba,不相同). 输入长度为 n 的串 S ,求 S 的最长双回文子串 T ,即可 ... 
- BZOJ.2565.[国家集训队]最长双回文串(Manacher/回文树)
		BZOJ 洛谷 求给定串的最长双回文串. \(n\leq10^5\). Manacher: 记\(R_i\)表示以\(i\)位置为结尾的最长回文串长度,\(L_i\)表示以\(i\)开头的最长回文串长 ... 
- [国家集训队]最长双回文串    manacher
		---题面--- 题解: 首先有一个直观的想法,如果我们可以求出对于位置i的最长后缀回文串和最长前缀回文串,那么我们枚举分界点然后合并前缀和后缀不就可以得到答案了么? 所以我们的目标就是求出这两个数列 ... 
随机推荐
- ☕【JVM技术指南】「JVM总结笔记」Java虚拟机垃圾回收认知和调优的"思南(司南)"【下部】
			承接上文 (完结撒花1-52系列)[JVM技术指南]「JVM总结笔记」Java虚拟机垃圾回收认知和调优的"思南(司南)"[上部] 并行收集器 并行收集器(也称为吞吐量收集器)是类似 ... 
- [第三篇]——CentOS Docker 安装之Spring Cloud直播商城 b2b2c电子商务技术总结
			CentOS Docker 安装 Docker 支持以下的 64 位 CentOS 版本: CentOS 7 CentOS 8 更高版本... 使用官方安装脚本自动安装 安装命令如下: curl -f ... 
- elasticsearch入门到放弃之elasticsearch-head
			elasticsearch-head可理解为跟DBeaver一样是一个数据可视化工具,但是这个工具并没有理想中那么好用坑也是很多,我已经在我的github上fork了一份修改后的版本:https:// ... 
- systemctl添加自定义系统服务
			[Service] Type=forking ExecStart=绝对路径 ExecStop=绝对路径 ExecReload=绝对路径 以上最精简版,文件/usr/lib/systemd/system ... 
- jmeter 参数化学习之CSV Data Set Config随机读取一行参数
			需要使用到循环控制器,if控制器,CSV Data Set Config,Random Variable 4个组件 如图 先在线程组下面放一个随机数生成器 然后在同一层级设置一个永久的循环控制器,记住 ... 
- Elasticsearch(ES)分词器的那些事儿
			1. 概述 分词器是Elasticsearch中很重要的一个组件,用来将一段文本分析成一个一个的词,Elasticsearch再根据这些词去做倒排索引. 今天我们就来聊聊分词器的相关知识. 2. 内置 ... 
- 无序数组求第K大的数
			问题描述 无序数组求第K大的数,其中K从1开始算. 例如:[0,3,1,8,5,2]这个数组,第2大的数是5 OJ可参考:LeetCode_0215_KthLargestElementInAnArra ... 
- git报错:Auto Merge Failed; Fix Conflicts and Then Commit
			本文来源:http://blog.csdn.net/trochiluses/article/details/101007191.出错场景: 协同开发时,我们从远程服务器上pull下代码的时候,出现以下 ... 
- 如何实现Orchard Core CMS的全文索引
			Orchard Core提供了Lucene功能,允许您在网站上进行全文搜索.大多数情况下,在运行博客或简单的代理网站时,您可能需要在页面内容中进行搜索.在Orchard Core中,您可以使用Liqu ... 
- 配置php redis 扩展
			参照runoob:PHP 使用 Redis Windows: - 假设redis已经安装好 服务启动 - xampp (php 7.1 x86 windows) 查看phpinfo (php 7.1 ... 
