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][ ...
随机推荐
- Day 3 - 单调栈、单调队列、凸包与斜率优化
单调栈 引入 何为单调栈?顾名思义,单调栈即满足单调性的栈结构.与单调队列相比,其只在一端进行进出. 为了描述方便,以下举例及伪代码以维护一个整数的单调递增栈为例. 过程 插入 将一个元素插入单调栈时 ...
- 【VMware VCF】VMware Cloud Foundation Part 02:部署 Cloud Builder。
VMware Cloud Builder 是用于构建 VMware Cloud Foundation 第一个管理域的自动化部署工具,通过将一个预定义信息的 Excel 参数表导入到 Cloud Bui ...
- 工作单元(UnitOfWork) 模式 (2) .NET Core
1.工作单元(UnitOfWork)是什么? Maintains a list of objects affected by a business transaction and coordinate ...
- 封装的grid控件
class CGridCtrl : public CWnd { DECLARE_DYNAMIC(CGridCtrl) public: void Create(CWnd* pParent, DWORD ...
- .NET 开源快捷的数据库文档查询和生成工具
前言 在实际项目开发中,需求变更和项目迭代是常态.要求我们能够迅速响应,对数据库结构进行相应的调整,如添加新表.更新现有表结构或增加字段等. 为了确保团队成员之间的信息同步,实时更新和维护数据库文档变 ...
- 【Java】Input,Output,Stream I/O流 03 系统标准流 & 打印流
Standard Input,Output Stream 标准输入输出流 - System.in 系统标准输入流 所属InputStream Scanner(System.in); 默认从键盘获取输入 ...
- 【RabbitMQ】04 路由模式
在订阅模式的基础上制定一些特定发送规则 创建路由模式的生产者: 注意这些变化,跟之前的订阅模式并不一样 package cn.dzz.routineQueueInProducer; import co ...
- 【Android】构建Android12项目报错
报错信息: Installed Build Tools revision 31.0.0 is corrupted. Remove and install again using the SDK Man ...
- Linux系统——删除用户命令
背景: 负责管理实验室的服务器,近期有保研的大三同学放弃保送到实验室而选择其他实验室,因此需要把之前给他开的账号取消掉. ===================================== ...
- Gitee官网大规模封禁开源项目,如想解禁则需手动提交审核,在此过程中一些项目的信息也被gitee官方修改!!!
由于美国政府对中国的各种打压和制裁,为了支持国产软件我已经将GitHub上的大多数代码库迁移到了gitee上,虽然我的开源库基本都是个人学习时候的一些代码并不是什么成品项目代码,但是不管力量大小也都支 ...