Manacher笔记
(其实还是回文自动机好用,毛子真是牛逼)
Manacher
#include<iostream>
#include<cstring>
#include<cstdio>
#include<cmath>
using namespace std;
char s[];
int manacher(char s[]){
int maxn=,p[],mx=,id=,len=strlen(s);
char st[];
st[]='$';
for(int i=;i<len;i++){
st[i*+]='#';
st[(i+)*]=s[i];
}
st[len*+]='#';
for(int i=;i<*len;i++){
if(i<mx)p[i]=min(p[id*-i],mx-i);
else p[i]=;
while(st[i-p[i]]==st[i+p[i]])p[i]++;
if(i+p[i]>mx){
mx=i+p[i];
id=i;
}
maxn=max(maxn,p[i]-);
}
return maxn;
}
int main(){
scanf("%s",s);
printf("%d",manacher(s));
return ;
}
毕竟是线性算法,又好背,尊重一下人家咯~
Manacher笔记的更多相关文章
- Manacher算法学习笔记 | LeetCode#5
		Manacher算法学习笔记 DECLARATION 引用来源:https://www.cnblogs.com/grandyang/p/4475985.html CONTENT 用途:寻找一个字符串的 ... 
- 学习笔记 - Manacher算法
		Manacher算法 - 学习笔记 是从最近Codeforces的一场比赛了解到这个算法的~ 非常新奇,毕竟是第一次听说 \(O(n)\) 的回文串算法 我在 vjudge 上开了一个[练习],有兴趣 ... 
- 【学习笔记】字符串—马拉车(Manacher)
		[学习笔记]字符串-马拉车(Manacher) 一:[前言] 马拉车用于求解连续回文子串问题,效率极高. 其核心思想与 \(kmp\) 类似:继承. --引自 \(yyx\) 学姐 二:[算法原理] ... 
- [Manacher]【学习笔记】
		终于填坑啦......马拉车 课件上说的好短,但是明白了,讲解稍微修改一下抄上行了,比扩展KMP好写多了 求以每个字符为中心的最长回文串的半径.如果要求可以以字符间隙为回文中心,就要在每两个字符之间及 ... 
- 「Manacher算法」学习笔记
		觉得这篇文章写得特别劲,插图非常便于理解. 目的:求字符串中的最长回文子串. 算法思想 考虑维护一个数组$r[i]$代表回文半径.回文半径的定义为:对于一个以$i$为回文中心的奇数回文子串,设其为闭区 ... 
- 算法笔记--manacher算法
		参考:https://www.cnblogs.com/grandyang/p/4475985.html#undefined 模板: ; int p[N]; string manacher(string ... 
- Manacher学习笔记
		目录 code(伪) Manacher算法 可在 \(O(n)\)的时间内求出一个字符串以每个位置为中心的最长回文子串. 原理:根据之前预处理出的回文串长度求得新的回文串长度 我们可以通过在字符中加上 ... 
- Manacher算法学习笔记
		前言 Manacher(也叫马拉车)是一种用于在线性时间内找出字符串中最长回文子串的算法 算法 一般的查找回文串的算法是枚举中心,然后往两侧拓展,看最多拓展出多远.最坏情况下$O(n^2)$ 然而Ma ... 
- 【学习笔记】Manacher
		扔板子跑路 代码 POJ3974 #include <cstdio> #include <cstring> #include <algorithm> using n ... 
随机推荐
- ZBrush中如何清除画布中多余图像
			ZBrush是一款数字雕刻与绘画软件,它以强大的功能和直观的工作流程彻底改变了整个三维行业.它的简洁化.智能化和人性化的设计无不让众多用户所折服.刚接触它的用户可能会因为找不到相关命令或不熟悉而觉得它 ... 
- [luogu 2568] GCD (欧拉函数)
			题目描述 给定整数N,求1<=x,y<=N且Gcd(x,y)为素数的数对(x,y)有多少对. 输入输出格式 输入格式: 一个整数N 输出格式: 答案 输入样例#1: 4 输出样例#1: 4 ... 
- 【技术翻译】SIFT算子原理及其实现 (一)介绍
			介绍 匹配不同图片的特征是计算机视觉常见的问题. 当所有要匹配的图片很相似的时候(大小,方位),简单的角点检测算子就可以匹配,但是,当你的图片大小,方位不同的时候,你就要用到尺度不变特征变换(scal ... 
- ubuntu18.04crontab定时任务不执行
			环境介绍: 本人使用python写了一个自动化提交巡检的脚本放在服务器上,使用crontab去执行脚本的时候动作并没有执行,查看crontab日志时也不存在这个日志文件.如何如排查呢? 解决方案: 步 ... 
- ElasticSearch启动报错,bootstrap checks failed
			修改elasticsearch.yml配置文件,允许外网访问. vim config/elasticsearch.yml# 增加 network.host: 0.0.0.0 启动失败,检查没有通过,报 ... 
- SparkSql初级编程实践
			1.Spark SQL 基本操作将下列 JSON 格式数据复制到 Linux 系统中,并保存命名为 employee.json.{ "id":1 , "name" ... 
- 小学生都能学会的python(<lamda匿名函数,sorted(),filter(),map(),递归函数>)
			小学生都能学会的python(<<lamda匿名函数,sorted(),filter(),map(),递归函数,二分法>> 1. lambda 匿名函数 lambda 参数: ... 
- 再识Quartz
			在之前的项目中使用过Quartz,但都是基于XML配置定义任务的.目前一个项目应用需要对任务进行创建.暂停.删除等动态管理.所以再次在网上翻了翻,再来好好重新认识下Quartz. 名词解释: sche ... 
- 洛谷 P1894 [USACO4.2]完美的牛栏The Perfect Stall
			P1894 [USACO4.2]完美的牛栏The Perfect Stall 题目描述 农夫约翰上个星期刚刚建好了他的新牛棚,他使用了最新的挤奶技术.不幸的是,由于工程问题,每个牛栏都不一样.第一个星 ... 
- soapUI 5.1.2 下载以及破解
			转:https://blog.csdn.net/weiqing723/article/details/78865734 
