manacher/马拉车常用用法一览
因为manacher算法把原来的字符串扩大了两倍,因此在应用时许多二级结论都非常不直观,现场推出来很麻烦,因此笔者在此做个简单整理,如果发现有错误或者有常用的我没有涉及到的,恳请在下方评论区指出,我会非常感谢。
#include<iostream>
#include<cstdio>
#include<cstring>
#define MAXN 200005
using namespace std;
char str[MAXN];
char ex[MAXN*];
int rad[MAXN*];
void make_char(const char *str,char *ex){
int l=strlen(str);
int i,j;
j=;
ex[]='$';
for(i=;i<l;i++){
ex[++j]='#';
ex[++j]=str[i];
}
ex[++j]='#';
ex[++j]='\0';
}
int manacher(const char *ex,int *rad){
int l1=strlen(ex);
int mx=,id=,i=;
int maxx=;
rad[]=;
for(i=;i<l1;i++){
if(i>=mx)rad[i]=;
else rad[i]=min(mx-i+,rad[*id-i]);
while(ex[i-rad[i]]==ex[i+rad[i]]){
rad[i]++;
}
if(i+rad[i]->mx){
id=i;
mx=i+rad[i]-;
}
maxx=max(maxx,rad[i]-);
}
return maxx;
}
int main(){
scanf("%s",str);
make_char(str,ex);
printf("%d\n",manacher(ex,rad));
return ;
}
1,rad数组虽然指的是回文半径,但是它的值减一和回文子串长度对应
因此,最长回文子串长度是
max(ans[i]-1)
2,怎么对应呢,引入一个“某位置在ex上对应位置”概念
str[i]对应于ex[2i+2]
str[l,r]对应于ex[2*l+2,2*r+2]
ex[l+r+2]是该子串在ex上的中点
要问str上的子串[l,r]是不是回文子串
只需判断rad[l+r+2]-1>=r-l+1即可
3,假设t是str上某个点,t为整数时此点为某个字符,t不是整数时夹在两个字符串中间
那么以t为中点的最长回文子串的长度是rad[ans[2t+2]]-1
令tmp=rad[ans[2t+2]]-2
对应到str上的字符串是str[t-(tmp/2),t+(tmp)/2)
4,子串的回文子串
对于子串str[l,r]
将ans[2l+1,2r+3]如此构造:
ans'[i]=min(ans[i],l-i+1,r-i+1)
配合数据结构食用更佳
manacher/马拉车常用用法一览的更多相关文章
- linux的vi编辑器常用用法一览
vi 命令用于编辑文本文件,语法: vi 文件名 vi 是一个比较强大的编辑工具,类似于windows下的notepad,但是功能要强大的多.vi分为三种模式,分别是“一般模式”,“编辑模式”,“命令 ...
- centos的vi常用用法
centos的vi常用用法 vi编辑器是所有Unix及Linux系统下标准的编辑器,它的强大不逊色于任何最新的文本编辑器,这里只是简单地介绍一下它的用法和一小部分指令.由于对Unix及Linux系统的 ...
- MySql与SqlServer的一些常用用法的差别
MySql与SqlServer的一些常用用法的差别 本文为转载 本文将主要列出MySql与SqlServer不同的地方,且以常用的存储过程的相关内容为主. 1. 标识符限定符 SqlServer [] ...
- [转]ssh常用用法小结
ssh常用用法小结 1.连接到远程主机: 命令格式 : ssh name@remoteserver 或者 ssh remoteserver -l name 说明:以上两种方式都可以远程登录到远程主机, ...
- 【三支火把】---一份程序看懂C程序printf()的几种常用用法
闲来继续巩固我的学习之路,今天略微整理了一下,C程序中Printf()的一些常用用法,虽然自己以前好像会,但是不够系统,今天大致整理了一些,先贴上来看看,以后在看到其他,继续补充,希望能帮到一些像我一 ...
- grep参数说明及常用用法
grep参数说明及常用用法 趁着午休的时间把自己经常使用的一些grep命令整理一下. 方便以后查看. 后续会逐步把awk/sed/find等常用的命令理一理. 增强下记忆. 也算是对得起自己了. ^^ ...
- ssh常用用法小结
ssh常用用法小结 1.连接到远程主机: 命令格式 : ssh name@remoteserver 或者 ssh remoteserver -l name 说明:以上两种方式都可以远程登录到远程主机, ...
- C# Linq基本常用用法
1.什么是Linq? Lanaguage Interated Query(语言集成查询),Linq 是集成C# 和VB这些语言中用于提供数据查询能力的一个新特性. 这里只介绍两种基本常用用法. 学习方 ...
- Java集合中迭代器的常用用法
该例子展示了一个Java集合中迭代器的常用用法public class LinkedListTest { public static void main(String[] args) { List&l ...
随机推荐
- linux部署tomcat项目
unzip apache-tomcat-7.0.55-windows- x64.zip 解压zip文件 chmod +x startup.sh shutdown.sh catalina.sh ...
- log4cplus TimeBasedRollingFileAppender
参考自:http://blog.csdn.net/u010607621/article/details/54944696 对于TimeBasedRollingFileAppender 这个日志appe ...
- 32. Random类
1.Random class Random implements java.io.Serializable 下面是一个简单验证码的代码: public static void main(String[ ...
- 七牛云-C#SDK-上传-前期准备
1.创建一个asp.net core MVC 程序(这里随便) 这是一个空的程序 2.创建UploadController 3.添加引用 Install-Package Newtonsoft.Json ...
- leetcood学习笔记-88-合并两个有序数组
题目描述: 第一次提交: class Solution: def merge(self, nums1: List[int], m: int, nums2: List[int], n: int) -&g ...
- rasa学习(domain.yml、nlu.md、stories.md)(一)
一. 什么是rasa Rasa是一个用于自动文本和基于语音的对话的开源机器学习框架.了解消息,保持对话以及连接到消息传递通道和API Rasa分为Rasa core和 Rasa nlu两部分: Ras ...
- delphi 安卓开发常用
delphi 安卓开发有几个常用的pas: FMX.Helpers.Android, Androidapi.JNI.Net, Androidapi.JNI.GraphicsContentViewTex ...
- 限时免费 GoodSync 10 同步工具【转】
一款不错的软件,正在开发本身的云盘,要是能够云执行任务就更好了! GoodSync 10是一种简单和可靠的文件备份和文件同步软件.它会自动分析.同步,并备份您的电子邮件.珍贵的家庭照片.联系人,.MP ...
- linux环境下创建domain
首先进入weblogic的安装目录,具体如下: cd /wls/Oracle/Middleware/Oracle_Home/wlserver/common/bin 图形化创建 1.下载xmanager ...
- HDU4578-代码一点都不长的线段树
(有任何问题欢迎留言或私聊 && 欢迎交流讨论哦 题意:传送门 原题目描述在最下面. 4种操作,1:区间加法,2:区间乘法,3:区间的所有数都变成一个数,4:访问区间每个数的p次方 ...