P4036 [JSOI2008] 火星人
#include <bits/stdc++.h>
#define int long long
using namespace std;
int len;
int m;
int rt = 0;
int has[1000010];
void init()
{
srand(1);
has[0] = 1;
for(int i = 1;i <= 1000000;i++)
has[i] = has[i - 1] * 101;
//cout << has[] << endl;
}
char s[1000010];
struct edge
{
int val;
int lson;
int s;
int rson;
int kth;
int siz;
}e[1000010];
int cnt = 0;
int newnode(int xx)
{
e[++cnt].val = xx;
e[cnt].kth = rand();
e[cnt].s = xx;
e[cnt].siz = 1;
return cnt;
}
void up(int x)
{
e[x].siz = e[e[x].lson].siz + e[e[x].rson].siz + 1;
e[x].s = e[e[x].lson].s * has[e[e[x].rson].siz + 1] + e[x].val * has[e[e[x].rson].siz] + e[e[x].rson].s;
}
int merge(int A,int B)
{
///cout << A << " " << B << endl;
if(!A || !B)return A + B;
if(e[A].kth < e[B].kth)
{
e[A].rson = merge(e[A].rson,B);
up(A);
return A;
}
else
{
e[B].lson = merge(A,e[B].lson);
up(B);
return B;
}
}
pair<int,int> split(int x,int val)
{
if(!x)return pair<int,int>();
///cout << x << endl;
if(val <= e[e[x].lson].siz)
{
pair<int,int> s = split(e[x].lson,val);
e[x].lson = s.second;
s.second = x;
up(x);
return s;
}
else
{
pair<int,int> s = split(e[x].rson,val - e[e[x].lson].siz - 1);
e[x].rson = s.first;
s.first = x;
up(x);
return s;
/* for(int i = 1;i <= len;i++)
{
printf("%d",f[i]);
}*/
}
}
int Has(int L,int R)
{
if(L > R)return 0;
pair<int,int> retl = split(rt,R);
pair<int,int> retr = split(retl.first,L - 1);
int res = e[retr.second].s;
retl.first = merge(retr.first,retr.second);
rt = merge(retl.first,retl.second);
///cout << L << " " << R << endl;
return res;
}
void add(int x,int val)
{
pair<int,int> retl = split(rt,x);
retl.first = merge(retl.first,newnode(val));
rt = merge(retl.first,retl.second);
len++;
}
int query(int x,int y)
{
int l = 0,r = min(len - x + 1,len - y + 1);
while(l < r)
{
//cout << l << " " << r << endl;
int mid = (l + r + 1) / 2;
if(Has(x,x + mid - 1) == Has(y,y + mid - 1))l = mid;
else r = mid - 1;
}
return l;
}
void updata1(int x,int val)
{
pair<int,int> retl = split(rt,x);
pair<int,int> retr = split(retl.first,x - 1);
e[retr.second].s = e[retr.second].val = val;
retl.first = merge(retr.first,retr.second);
rt = merge(retl.first,retl.second);
}
signed main()
{
init();
int x,y;
scanf("%s",s + 1);
scanf("%lld",&m);
len = strlen(s + 1);
for(int i = 1;i <= len;i++)
rt = merge(rt,newnode(s[i] - 'a' + 1));
for(int i = 1;i <= m;i++)
{
scanf("%s",s + 1);
if(s[1] == 'Q')
{
scanf("%lld%lld",&x,&y);
printf("%lld\n",query(x,y));
}
else if(s[1] == 'R')
{
scanf("%lld%s",&x,s + 1);
updata1(x,s[1] - 'a' + 1);
}
else
{
scanf("%lld %s",&x,s + 1);
add(x,s[1] - 'a' + 1);
}
}
return 0;
}
P4036 [JSOI2008] 火星人的更多相关文章
- P4036 [JSOI2008]火星人(splay+hash+二分)
P4036 [JSOI2008]火星人 Splay维护hash,查询二分 $a[x].vl=a[lc].vl*ha[a[rc].sz+1]+a[x].w*ha[a[rc].sz]+a[rc].vl$ ...
- bzoj 1014: 洛谷 P4036: [JSOI2008]火星人
题目传送门:洛谷P4036. 题意简述: 有一个字符串,支持插入字符,修改字符. 每次需要查询两个后缀的LCP长度. 最终字符串长度\(\le 100,\!000\),修改和询问的总个数\(\le 1 ...
- luogu P4036 [JSOI2008]火星人
传送门 很久以前xzz大佬就喊我做这题,结果现在才做qwq 因为要在序列中插入,所以直接用\(Splay\)维护这个串的哈希值,插入就直接把那个点插♂进去,修改就把点旋到根,然后修改和pushup,询 ...
- 洛谷 P4036 [JSOI2008]火星人(splay+字符串hash)
题面 洛谷 题解 首先,我们知道求最长公共前缀可以用二分答案+hash来求 因为有修改操作, 考虑将整个字符串的hash值放入splay中 接着就是splay的基本操作了 Code #include& ...
- 1014: [JSOI2008]火星人prefix
1014: [JSOI2008]火星人prefix Time Limit: 10 Sec Memory Limit: 162 MB Description 火星人最近研究了一种操作:求一个字串两个后缀 ...
- [BZOJ1014][JSOI2008]火星人prefix
[BZOJ1014][JSOI2008]火星人prefix 试题描述 火星人最近研究了一种操作:求一个字串两个后缀的公共前缀.比方说,有这样一个字符串:madamimadam,我们将这个字符串的各个字 ...
- BZOJ 1014: [JSOI2008]火星人prefix [splay 二分+hash] 【未完】
1014: [JSOI2008]火星人prefix Time Limit: 10 Sec Memory Limit: 162 MBSubmit: 6243 Solved: 2007[Submit] ...
- 【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][ ...
随机推荐
- 计算机二级考试 C语言篇
本篇仅适用于计算机二级考试C语言篇 首先介绍一下二级考试时间问题(以本人考试2022年为例): 一. 2022年全国计算机二级考试时间 2022年全国计算机考试举办4次,(3月.5月.9月.12月 ...
- Goutte爬虫
安装 composer require fabpot/goutte:4.0
- 小狼毫&雾凇拼音安装及部署-Windows(图文)
小狼毫输入法和雾凇拼音主题安装以及配置步骤 先上资源链接 小狼毫官网:RIME | 中州韻輸入法引擎 小狼毫Github地址:rime/weasel: [小狼毫]Rime for Windows (g ...
- android实现多线程基础
//创建线程类 class Mythread extends Thread{ @Override public void run(){ //定义行为 } } //实例化线程类 MyThread mt= ...
- keycloak~为微信二维码添加动态kc认可的动态state
本实例将通过keycloak社区登录实现微信二维码的登录,并且二微码不是keycloak动态生成,而是通过微信提供的js生成的,在页面上直接输出的方式实现的. 动态state 在Keycloak中使用 ...
- Jmeter函数助手8-counter
counter函数用于线程计数,类似计数器. TRUE每个用户有自己的计数器:FALSE使用全局计数器:即线程之间是否需要共享累加计数器,TRUE否,FALSE是 存储结果的变量名(可选) 1.线程之 ...
- postfix&dovecot搭建邮件服务器
本篇参考 https://blog.51cto.com/5001660/2377785和小翔博客https://www.liuyixiang.com/post/113927.html. 邮件发送和接受 ...
- 【Vue】14 UI库
PC端: 第一梯队:基于JQuery实现的Dom操作,和一些简单CSS样式组成 Layui Bootstrap EasyUI 第二梯队:基于Vue2.0开发的UI库,组件化开发 ElementUI A ...
- 强化学习算法:Learning to Learn: Meta-Critic Networks for Sample Efficient Learning
地址: https://arxiv.org/pdf/1706.09529 作者提出了一种叫做Meta-Critic的框架,该框架可以用于强化学习.监督学习等算法中.该算法在强化学习中可以实现元强化学习 ...
- 始智AI —— https://wisemodel.cn/ —— 试用
清华大学的合资企业推出的服务: 始智AI -- https://wisemodel.cn/ 链接: 始智AI -- https://wisemodel.cn/ 和modelscope比相对简约,毕竟功 ...