P4036-[JSOI2008]火星人【Splay,二分,hash】

正题

题目链接:https://www.luogu.com.cn/problem/P4036


题目大意

一个字符串要求支持

  1. 插入一个字符
  2. 修改一个字符
  3. 询问两个后缀的最长公共前缀。

解题思路

如果不考虑修改我们可以用二分+hash+hash+hash解决该问题,但是涉及到修改和插入我们考虑用SplaySplaySplay维护hashhashhash值。

合并时使用hash=hashl∗psizr+1+val∗psizr+hashrhash=hash_l*p^{siz_r+1}+val*p^{siz_r}+hash_rhash=hashlpsizr+1+valpsizr+hashr进行合并即可。


codecodecode

#include<cstdio>
#include<cstring>
#include<algorithm>
#define ull unsigned long long
using namespace std;
const int N=2e5+10;
const ull base=131;
struct node{int siz;ull val,hash;
}a[N];
int n,root,tot,m;
int t[N][2],fa[N];
char s[N];
ull p[N];
bool Direct(int x)
{return t[fa[x]][1]==x;}
void Merge(int x){a[x].siz=a[t[x][0]].siz+a[t[x][1]].siz+1;a[x].hash=p[a[t[x][1]].siz+1]*a[t[x][0]].hash+p[a[t[x][1]].siz]*a[x].val+a[t[x][1]].hash;
}
void Connect(int x,int y,int dir)
{t[x][dir]=y;fa[y]=x;}
void Rotate(int x){int y=fa[x],root=fa[fa[x]];int ys=Direct(x),rs=Direct(y);int z=t[x][ys^1];Connect(y,z,ys);Connect(x,y,ys^1);Connect(root,x,rs);Merge(y);Merge(x);return;
}
void Splay(int x,int f)
{while(fa[x]!=f){int up=fa[x];if(fa[up]==f) Rotate(x);else if(Direct(x)==Direct(up))Rotate(up),Rotate(x);else Rotate(x),Rotate(x);	}return;
}
int Find(int x,int k)
{if(a[t[x][0]].siz>=k) return Find(t[x][0],k);if(a[t[x][0]].siz+1==k) return x;return Find(t[x][1],k-a[t[x][0]].siz-1);
}
int Split(int l,int r)
{int x=Find(root,l),y=Find(root,r+2);Splay(x,0);Splay(y,x);root=x;return t[y][0];
}
ull ValSeq(int x,int y)
{return a[Split(x,y)].hash;
}
int main()
{scanf("%s",s+1);n=strlen(s+1);a[1].siz=p[0]=1;for(int i=1;i<N;i++)p[i]=p[i-1]*base;for(int i=1;i<=n;i++){a[i+1].val=s[i]-'a'+1;fa[i]=i+1;t[i+1][0]=i;Merge(i+1);}fa[n+1]=n+2;t[n+2][0]=n+1;Merge(n+2);root=tot=n+2;scanf("%d",&m);while(m--){char op[2];scanf("%s",op);if(op[0]=='Q'){int x,y;scanf("%d%d",&x,&y);int l=0,r=min(n-x,n-y);while(l<=r){int mid=(l+r)/2;if(ValSeq(x,x+mid)==ValSeq(y,y+mid)) l=mid+1;else r=mid-1;}printf("%d\n",r+1);}if(op[0]=='R'){int x;char c[2];scanf("%d%s",&x,c);int k=Split(x,x);a[k].val=a[k].hash=c[0]-'a'+1;Splay(k,0);root=k;}if(op[0]=='I'){int x;char c[2];scanf("%d%s",&x,c);x++;int l=Find(root,x),r=Find(root,x+1);Splay(l,0);Splay(r,l);n++;fa[++tot]=r;t[r][0]=tot;a[tot].siz=1;a[tot].val=a[tot].hash=c[0]-'a'+1;Splay(tot,0);root=tot;}} 
}

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

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

相关文章

36、JAVA_WEB开发基础之监听器

是什么 顾名思义就是监听器就是监听器&#xff0c;在开发中指的是一种机制&#xff0c;通过这种机制可以对应用中组件的创建、销毁、更改等动作进行监视&#xff0c;根据具体监听信息作出相应的处理 工作原理 就是预先给组件添加一个事件&#xff0c;当这个组件被操作&#…

2017西安交大ACM小学期 神器插座 KMP匹配

神奇插座 发布时间: 2017年7月3日 11:27 最后更新: 2017年7月5日 13:46 时间限制: 500ms 内存限制: 128M 描述 AA所在的国家有一项神奇的发明&#xff1a;插座。这里的插座不仅有两孔、三孔&#xff0c;而是有多种形态&#xff0c;下面用不同的小写字母表示不同的插座。插…

jzoj3626-[LNOI2014]LCA【树链剖分,线段树】

正题 题目链接:https://www.lydsy.com/JudgeOnline/problem.php?id3626 题目大意 一棵树&#xff0c;每次给出(l,r,z)(l,r,z)(l,r,z)询问∑ilrdepLCA(i,z)\sum_{il}^rdep_{LCA(i,z)}il∑r​depLCA(i,z)​ 解题思路 若询问LCA(x,y)LCA(x,y)LCA(x,y)的深度有一种方法&#xf…

37、JAVA_WEB开发基础之上传功能

是什么 上传指的是将客户端的文件保存到服务器的磁盘中 基本实现原理 读取客户端的文件信息&#xff0c;将文件信息以流的形式发送到服务器&#xff0c;然后服务器将流中的信息保存到本地&#xff0c;以实现文件的上传 实例 注意&#xff1a;提交的表单类型一定是 enctype…

2017西安交大ACM小学期 文本查找[AC自动机]

文本查找 发布时间: 2017年7月5日 00:10 最后更新: 2017年7月5日 13:47 时间限制: 1500ms 内存限制: 128M 描述 给定m种两两不同的关键词&#xff0c;并给定一段文本&#xff0c;问这段文本中有几种关键词出现&#xff08;一种关键词出现多次只算一次&#xff09;。 输入…

P4296-[AHOI2007]密码箱【数论】

正题 题目链接:https://www.luogu.com.cn/problem/P4296 题目大意 一个数字nnn&#xff0c;求有多少个x<nx<nx<n使得x2%n1x^2\%n1x2%n1。 解题思路 x2kn1x^2kn1x2kn1 x2−1knx^2-1knx2−1kn (x−1)(x1)%n0(x-1)(x1)\%n0(x−1)(x1)%n0 ⇒\Rightarrow⇒ x(x2)%n0(x2&l…

38、JAVA_WEB开发基础之下载功能

是什么 下载指的是将服务器端的文件保存到客户端的磁盘中 基本实现原理 根据对应的要下载的文件在服务器端找到对应的文件&#xff0c;然后获取到文件流对象&#xff0c;将流对象发送到客户端&#xff0c;然后客户端通过对返回结果中文件流的解析&#xff0c;将流对象转换成…

2017西安交大ACM小学期 有趣异或[Trie树]

有趣异或 发布时间: 2017年7月4日 23:59 最后更新: 2017年7月5日 14:56 时间限制: 1500ms 内存限制: 512M 描述 给定n个非负整数&#xff0c;保证这些数两两不相同。现给定x&#xff0c;请从中选2个不同的数a,b&#xff0c;使得a^b^x最大。 输入 包含多组测试数据。 每组…

P5675-[GZOI2017]取石子游戏【博弈论,dp】

正题 题目链接:https://www.luogu.com.cn/problem/P5675 题目大意 nnn堆石子&#xff0c;第iii堆有aia_iai​个。指定一些石子堆使得先手必胜并指定一个先手第一个取的位置使得先手必败&#xff0c;求有多少方案数。 解题思路 根据NIMNIMNIM游戏&#xff0c;只要石子数异或和…

39、JAVA_WEB开发基础之ajax和json

ajax是什么 首先要知道ajax并不是一种新的技术&#xff0c;而是几种技术的强强联合&#xff0c;全称是Asynchronous Javascript and xml&#xff0c;其精髓在于异步加载资源&#xff0c;因此可以实现局部加载效果&#xff08;因为可以异步加载&#xff0c;所以不需要依靠整张页…

(不误正业)鼓励做题的时间陷阱

前言 在家闲的无聊想着没人陪我做题就写了一个可以(或许)鼓励做题的东西 正题 关于时间陷阱 时间陷阱是种游戏类型&#xff0c;玩家开始时有一个倒计时&#xff0c;没完成一个任务会增加倒计时&#xff0c;时间到了那么任务就输了。 这里编写的时间陷阱任务重要度(完成后加的…

2017西安交大ACM小学期 美妙音乐[差分KMP匹配]

美妙音乐 发布时间: 2017年7月3日 13:14 最后更新: 2017年7月5日 13:47 时间限制: 500ms 内存限制: 128M 描述 一段音乐是由若干个音符组成的&#xff0c;音乐中的某段音符称为旋律。给定一首音乐&#xff0c;问某个旋律出现了多少次。注意&#xff1a; &#xff08;1&am…

1、数据库简介

数据库是什么 数据库是一种用来存储数据的仓库&#xff0c;是一种高效存储和处理数据的介质&#xff08;载体&#xff09;。我们通常口中所说的数据库指的是数据库管理系统&#xff08;DBMS&#xff09;&#xff0c;是一种用于方便管理数据库的软件。 数据库的分类 根据存储…

P2387-[NOI2014]魔法森林【LCT】

前言 话说LCTLCTLCT的SplaySplaySplay和平时写的SplaySplaySplay差别好大&#xff0c;调了我半天 正题 题目链接:[https://www.luogu.com.cn/problem/P2387 题目大意 nnn个点mmm条边有a,ba,ba,b两个值&#xff0c;求一条路径从1−>n1->n1−>n使得路径上最大的aaa加上…

2017西安交大ACM小学期 敏感词汇[AC自动机]

敏感词汇 发布时间: 2017年7月5日 00:23 最后更新: 2017年7月6日 14:40 时间限制: 1500ms 内存限制: 128M 描述 我们知道&#xff0c;在进行聊天时&#xff0c;有些词汇是敏感词汇&#xff0c;含有敏感词汇的内容是不允许被发送的。现在给定m个敏感词汇&#xff0c;并给定…

2、安装和连接mysql

安装mysql 1、官网下载mysql 下载网址&#xff1a;https://www.mysql.com/ 2、解压并配置mysql 解压下载的&#xff08;前提下载的zip版本的mysql&#xff09;mysql安装包&#xff0c;放到指定磁盘 配置环境变量&#xff1a;将mysql下的bin目录的全路径名配置到环境变量的p…

51nod-诺德街【数学期望】

正题 题目链接:http://www.51nod.com/Contest/Problem.html#contestProblemId305 题目大意 nnn个商铺&#xff0c;第iii个商铺有pip_ipi​的概率营业&#xff0c;一个人从111走到nnn再走回来一直重复&#xff0c;如果走到没有人营业的商铺那么就结束。 求期望走多少个商铺后停…

ACM一类方程问题的求解[最短路建模] bzoj2118

在ACM生涯里已经预见两回判断这种方程是否有解、有几个解的问题了。 例如&#xff1a; 1 给定非负整数a,b,c,n&#xff0c;请判断axbyczn是否存在(x,y,z)均为非负整数的解 题目链接&#xff1a;http://oj.xjtuacm.com/contest/14/problem/124/ 再例如&#xff1a; 2 现有…

3、数据库中的字符集和校对集

字符集 字符集指的就是存储数据到硬盘时用到的编码方式&#xff0c;mysql中操作字符集的基本sql如下&#xff1a; show character set; -- 查看服务器支持哪些字符集 show variables like ‘character_set%’; -- 查看服务器对外处理的默认字符集 set character_set_clien…

P3810-[模板]三维偏序(陌上花开)【CDQ分治,树状数组】

正题 题目链接:https://www.luogu.com.cn/problem/P3810 题目大意 nnn个三元组(a,b,c)(a,b,c)(a,b,c)&#xff0c;f(i)∑i1n,j≠i[aj≤ai&bj≤bi&bj≤bi]f(i)\sum_{i1}^{n,j\neq i}[a_j\leq a_i\&b_j\leq b_i\&b_j\leq b_i]f(i)i1∑n,j​i​[aj​≤ai​&…