[JSOI2008]火星人 题解
原题链接:\(luogu\)$\ \ $ \(BZOJ\)$\ \ $ \(LOJ\)
题目大意:有一个可以支持插入和修改的字符串,定义函数 \(\operatorname{LCQ(x,y)}\) 表示从 \(x\) 开始的后缀与从 \(y\) 开始的后缀的最长公共前缀。
声明变量:
\(ls\):左儿子
\(rs\):右儿子
\(val\):平衡树维护变量,此题指字符 -'a'
\(sz\):子树大小
\(rk\):对应堆值
\(hs\):哈希值,后面会讲
\(pq\):哈希对应要乘的数字
考虑既然是求最长公共前缀,当然可以通过二分长度来求,用哈希维护即可。
要支持插入和修改,很显然可以用平衡树的 \(FHQ\ Treap\) 进行区间维护。
在原先 \(FHQ\) 需要维护的五个量的基础上,加入 \(hs\),表示其子树内的 \(hash\) 值。
转移方程即为:\(hs[x]=hs[ls[x]]+val[x]\times pq[sz[ls[x]]]+hs[rs[x]]\times pq[sz[ls[x]]+1]\)
插入修改按 \(FHQ\) 原先操作即可
代码:
#include<bits/stdc++.h>
#define ls(x) pl[x].ls
#define rs(x) pl[x].rs
#define val(x) pl[x].val
#define sz(x) pl[x].sz
#define rk(x) pl[x].rk
#define hs(x) pl[x].hs
#define ull unsigned long long
using namespace std;
struct fhq{
int ls,rs,val,sz,rk;ull hs;
}pl[100005];
int fhq_fail;
ull q=1145141,pq[250005];
int make_node(int x){
int a=++fhq_fail;
pl[a]={0,0,x,1,rand(),x};
return a;
}struct fhq_treap{
int rt,x,y,z;fhq_treap(){rt=x=y=z=0;}
void pushup(int p){
sz(p)=sz(ls(p))+sz(rs(p))+1;
hs(p)=hs(ls(p))+val(p)*pq[sz(ls(p))]+hs(rs(p))*pq[sz(ls(p))+1];
}void split(int p,int a,int &x,int &y){
if(!p){x=y=0;return;}
if(sz(ls(p))<a) x=p,split(rs(p),a-sz(ls(p))-1,rs(p),y);
else y=p,split(ls(p),a,x,ls(p));pushup(p);
}int merge(int x,int y){
if(!x||!y) return x+y;
if(rk(x)<rk(y)){
rs(x)=merge(rs(x),y);
pushup(x);return x;
}ls(y)=merge(x,ls(y));
pushup(y);return y;
}void add(int a,int b){
split(rt,a,x,y);
rt=merge(merge(x,make_node(b)),y);
}void change(int a,int b){
split(rt,a,x,z);split(x,a-1,x,y);
val(y)=hs(y)=b;rt=merge(merge(x,y),z);
}ull ghs(int l,int r){
split(rt,r-1,x,z);split(x,l-1,x,y);
ull re=hs(y);rt=merge(merge(x,y),z);return re;
}
}a;int n,m;string s;
int main(){
ios::sync_with_stdio(0);cin.tie(0);
srand(19820422);cin>>s>>m;
n=s.size();pq[0]=1;
for(int i=1;i<=n+m;i++) pq[i]=pq[i-1]*q;
for(int i=0;s[i];i++) a.rt=a.merge(a.rt,make_node(s[i]-'a'));
while(m--){
char c;int x;cin>>c>>x;
if(c=='Q'){
int y;cin>>y;if(x>y) swap(x,y);
int l=1,r=sz(a.rt)-y+1,ans=0;
while(l<=r){
int mid=(l+r)/2;
if(a.ghs(x,x+mid)==a.ghs(y,y+mid))
l=mid+1,ans=mid;else r=mid-1;
}cout<<ans<<"\n";continue;
}char d;cin>>d;
if(c=='R') a.change(x,d-'a');
else a.add(x,d-'a');
}return 0;
}//Kaká
[JSOI2008]火星人 题解的更多相关文章
- [BZOJ1014][JSOI2008]火星人prefix
[BZOJ1014][JSOI2008]火星人prefix 试题描述 火星人最近研究了一种操作:求一个字串两个后缀的公共前缀.比方说,有这样一个字符串:madamimadam,我们将这个字符串的各个字 ...
- 【bzoj1014】[JSOI2008]火星人prefix
1014: [JSOI2008]火星人prefix Time Limit: 10 Sec Memory Limit: 162 MBSubmit: 6031 Solved: 1917[Submit] ...
- BZOJ 1014: [JSOI2008]火星人prefix Splay+二分
1014: [JSOI2008]火星人prefix 题目连接: http://www.lydsy.com/JudgeOnline/problem.php?id=1014 Description 火星人 ...
- JSOI2008 火星人prefix
1014: [JSOI2008]火星人prefix Time Limit: 10 Sec Memory Limit: 162 MBSubmit: 2918 Solved: 866[Submit][ ...
- 【BZOJ1014】[JSOI2008]火星人prefix Splay+hash
[BZOJ1014][JSOI2008]火星人prefix Description 火星人最近研究了一种操作:求一个字串两个后缀的公共前缀.比方说,有这样一个字符串:madamimadam,我们将这个 ...
- 1014: [JSOI2008]火星人prefix
1014: [JSOI2008]火星人prefix Time Limit: 10 Sec Memory Limit: 162 MB Description 火星人最近研究了一种操作:求一个字串两个后缀 ...
- BZOJ 1014: [JSOI2008]火星人prefix [splay 二分+hash] 【未完】
1014: [JSOI2008]火星人prefix Time Limit: 10 Sec Memory Limit: 162 MBSubmit: 6243 Solved: 2007[Submit] ...
- bzoj 1014: [JSOI2008]火星人prefix hash && splay
1014: [JSOI2008]火星人prefix Time Limit: 10 Sec Memory Limit: 162 MBSubmit: 3154 Solved: 948[Submit][ ...
- 求帮看!!!!BZOJ 1014 [JSOI2008]火星人prefix
1014: [JSOI2008]火星人prefix Time Limit: 10 Sec Memory Limit: 162 MBSubmit: 4164 Solved: 1277[Submit] ...
- BZOJ 1014: [JSOI2008]火星人prefix( splay + hash )
用splay维护序列, 二分+hash来判断LCQ.. #include<bits/stdc++.h> using namespace std; typedef unsigned long ...
随机推荐
- uniapp+vue3酒店预订|vite5+uniapp预约订房系统模板(h5+小程序+App端)
自研uni-app+vue3+uv-ui跨三端仿同程/携程酒店预订系统Uni-Vue3-WeTrip. uniapp-vue3-wetrip原创基于vite5+uniapp+pinia2+uni-ui ...
- GObject学习笔记(二)类型创建与注册
前言 本文可在https://paw5zx.github.io/GObject-tutorial-beginner-02/中阅读,体验更加 在上一节中我们介绍了GObject类型的类和实例变量的创建和 ...
- AlertManager警报通知 使用webhook 钉钉机器人
# AlertManager警报通知 使用webhook 钉钉机器人 #启动钉钉webhook服务 #dingtalk webhook docker rm -f dingtalk docker run ...
- 【报错解决】【Vue】与后端交互时,http与https跨域问题
问题 xhr.js:220 Mixed Content: The page at 'https://xxx' was loaded over HTTPS, but requested an insec ...
- Jackson ObjectMapper - 指定对象属性的序列化顺序
注释很有用,但在任何地方应用起来都会很痛苦.您可以配置整个 ObjectMapper 以这种方式工作 当前杰克逊版本: objectMapper.configure(MapperFeature.SOR ...
- set -euxo pipefail
有些开发人员会用Bash来实现很复杂的功能,就像使用别的高级语言一样.他可能觉得自己很牛逼但其他人早就想锤爆他了,Bash的可读性和可维护性远远低于任何高级语言.更要命的是,Bash并没有方便的调试工 ...
- [转]C# 组合查询条件
在我们开发过程中经常会遇见一些通过条件获取数据的功能,比如说获取我们的用户信息,查询输入框有用户姓名,部门,入职年份等等,但查询时可能只输入一个条件或多个条件,像这种不确定的查询时,我们应该如何处理. ...
- 基于开源IM即时通讯框架MobileIMSDK:RainbowChat v10.0版已发布
关于MobileIMSDK MobileIMSDK 是一套专门为移动端开发的开源IM即时通讯框架,超轻量级.高度提炼,一套API优雅支持UDP .TCP .WebSocket 三种协议,支持iOS.A ...
- 开源即时通讯IM框架 MobileIMSDK v6.2 发布
一.更新内容简介 本次更新为次要版本更新,进行了若干优化(更新历史详见:码云 Release Nodes).可能是市面上唯一同时支持 UDP+TCP+WebSocket 三种协议的同类开源IM框架. ...
- WPF 记录鼠标、触摸多设备混合输入场景问题
本文记录在WPF应用中鼠标.触摸混合输入,鼠标事件抬起时不会有MouseUp事件触发的问题. 事件输入我们都知道有3类:鼠标.触摸.触笔,鼠标是windows系统出来就有的事件,后面加了触笔.触摸. ...