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][ ...
随机推荐
- Android SDK Build-tools的版本已经高于Android SDK Platform-tools版本 的解决办法
解决Unknown error: Unable to build: the file dx.jar was not loaded from the SDK folder!最近渐渐迁移到Android ...
- Python Kafka客户端confluent-kafka学习总结
实践环境 Python 3.6.2 confluent-kafka 2.2.0 confluent-kafka简介 Confluent在GitHub上开发和维护的confluent-kafka-pyt ...
- 由delete语句引起的锁范围扩大
由delete语句引起的锁范围扩大 阿里云月报中的一句话,出处:http://mysql.taobao.org/monthly/2022/01/01/ 但是Ghost Record是可以跟正常的Rec ...
- 4、SpringBoot2之整合SpringMVC
创建名为springboot_springmvc的新module,过程参考3.1节 4.1.重要的配置参数 在 spring boot 中,提供了许多和 web 相关的配置参数(详见官方文档),其中有 ...
- 【Python】Django学习1
按黑马程序员的美多商场作方向: https://www.bilibili.com/video/BV1nf4y1k7G3 一.应用创建.注册处理.配置 Pycharm 创建Django项目: 自应用注册 ...
- 【Java】将枚举类转换为Redis字典缓存
字典翻译框架实现看这篇: https://www.cnblogs.com/mindzone/p/16890632.html 枚举的特性 首先是枚举的一些特性: 1.枚举实例直接在枚举类中声明 2.重载 ...
- 【节选 转载】人形机器人Optimus擎天柱技术解析
参考原文: https://www.sohu.com/a/589454391_383324?scm=9010.8000.0.0.1265 可以利用动作捕捉"学习"人类动作,依靠视觉 ...
- 强化学习中的“sample efficiency”应该如何翻译 —— “样本效率”还是“采样效率”
问题: 强化学习中的"sample efficiency"应该如何翻译 -- "样本效率"还是"采样效率" 答案: 具体看上下文内容.如果是 ...
- CF208E 题解
Blood Cousins 前置知识:线段树合并. 我们先把题目转化一下.这里先设 \(v\) 的 \(p\) 级祖先为 \(u\),事实上要求的东西就是 \(u\) 的 \(p\) 级后代的个数减 ...
- 【CDQ分治】三元环
三元环 HDU - 7439 思路 考虑 \(3\) 个点的有向图,要么成环,要么有一个点入度为 \(2\) ,假设第 个点的入度为 \(d_i\),答案为 \(C_n^3-\sum\limits_{ ...