bzoj1014: [JSOI2008]火星人prefix splay+hash
我写的代码好像自古以来就是bzoj不友好型的
本地跑的比std快,但是交上去巧妙被卡
答案。。。应该是对的,拍了好久了
#include <bits/stdc++.h>
#define MOD 998244353
#define mid (l+r>>1)
using namespace std;
int n,m,x,y;char ch;
long long mi[];
struct spla
{
int c[][],fa[],ch[],size[],ha[];
int rt,cnt;
void up(int now)
{
size[now]=size[c[now][]]+size[c[now][]]+;
ha[now]=(ha[c[now][]]+mi[size[c[now][]]]*ch[now]%MOD+mi[size[c[now][]]+]*ha[c[now][]]%MOD)%MOD;
}
void rot(int x,int &root)
{
int y=fa[x],k=c[y][]==x;
if(y!=root) c[fa[y]][c[fa[y]][]==y]=x;
else root=x;
fa[x]=fa[y];
fa[y]=x;
fa[c[x][!k]]=y;
c[y][k]=c[x][!k];
c[x][!k]=y;
up(y);up(x);
}
void splay(int x,int &root)
{
for(int y=fa[x];x!=root;rot(x,root),y=fa[x])
if(y!=root)
rot(((c[fa[y]][]==y)^(c[y][]==x))?x:y,root);
}
void add(int x,int y)
{
ch[++cnt]=y;size[cnt]=;ha[cnt]=y;
if(!rt)
{
rt=cnt;
return;
}
if(x==)
{
splay(fin(),rt);
c[rt][]=cnt;fa[cnt]=rt;
return;
}
splay(fin(x),rt);
if(x==n)
c[rt][]=cnt,fa[cnt]=rt;
else
splay(fin(x+),c[rt][]),c[c[rt][]][]=cnt,fa[cnt]=c[rt][];
}
/*
void add(int x,int y)
{
ch[++cnt]=y;size[cnt]=1;ha[cnt]=y;
if(!rt)
{
rt=cnt;
return;
}
int now=rt;
while(1)
{
if(x>size[c[now][0]])
if(c[now][1]) x-=size[c[now][0]]+1,now=c[now][1];
else
{
c[now][1]=cnt;fa[cnt]=now;
splay(cnt,rt);
return;
}
else
if(c[now][0]) now=c[now][0];
else
{
c[now][0]=cnt;fa[cnt]=now;
splay(cnt,rt);
return;
}
}
}*/
int fin(int x)
{
int now=rt;
while(x> || c[now][])
{
if(x==size[c[now][]]+)
break;
if(x>size[c[now][]])
x-=size[c[now][]]+,now=c[now][];
else
now=c[now][];
}
return now;
}
void change(int x,int y)
{
int now=fin(x);
splay(now,rt);
ch[now]=y;
up(now);
}
int hash(int x,int y)
{
if(x== && y==n) return ha[rt];
if(x==)
{
splay(fin(y+),rt);
return ha[c[rt][]];
}
if(y==n)
{
splay(fin(x-),rt);
return ha[c[rt][]];
}
splay(fin(x-),rt);
splay(fin(y+),c[rt][]);
return ha[c[c[rt][]][]];
}
} sp;
inline int read()
{
char ch=getchar();
for(;!isdigit(ch);ch=getchar());
int re=;
bool fl=;
if (ch=='-')
{
re=;
ch=getchar();
}
while (isdigit(ch))
{
re=re*+ch-'';
ch=getchar();
}
return fl?re:-re;
}
inline void write(int re)
{
if (re<)
{
putchar('-');
re=-re;
}
if (re>) write(re/);
putchar(re%+'');
}
void work(int x,int y)
{
if(x>y) swap(x,y);
int l=,r=n-y+;
while(l<r)
if(sp.hash(x,x+mid-)==sp.hash(y,y+mid-)) l=mid+;
else r=mid;
write(l-);puts("");
}
int main()
{
mi[]=;
for(int i=;i<=;i++)
mi[i]=mi[i-]*%MOD;
for(ch=getchar();isalpha(ch);ch=getchar())
sp.add(n,ch-'a'+),++n;
m=read();
for(int i=;i<=m;i++)
{
for(ch=getchar();!isalpha(ch);ch=getchar());
x=read();
if(ch=='Q') y=read();
else
{
char cas=ch;
for(ch=getchar();!isalpha(ch);ch=getchar());
y=ch-'a'+;
ch=cas;
}
if(i==)
int e=;
if(ch=='Q') work(x,y);
else
if(ch=='R')
sp.change(x,y);
else
sp.add(x,y),++n;
}
return ;
}
bzoj1014: [JSOI2008]火星人prefix splay+hash的更多相关文章
- bzoj1014: [JSOI2008]火星人prefix splay+hash+二分
Description 火星人最近研究了一种操作:求一个字串两个后缀的公共前缀.比方说,有这样一个字符串:madamimadam,我们将这个字符串的各个字符予以标号:序号: 1 2 3 4 5 6 7 ...
- 【BZOJ1014】[JSOI2008]火星人prefix Splay+hash
[BZOJ1014][JSOI2008]火星人prefix Description 火星人最近研究了一种操作:求一个字串两个后缀的公共前缀.比方说,有这样一个字符串:madamimadam,我们将这个 ...
- BZOJ 1014: [JSOI2008]火星人prefix( splay + hash )
用splay维护序列, 二分+hash来判断LCQ.. #include<bits/stdc++.h> using namespace std; typedef unsigned long ...
- BZOJ 1014 [JSOI2008]火星人prefix (Splay + Hash + 二分)
1014: [JSOI2008]火星人prefix Time Limit: 10 Sec Memory Limit: 162 MBSubmit: 8112 Solved: 2569[Submit] ...
- 【bzoj1014】[JSOI2008]火星人prefix Splay+Hash+二分
题目描述 火星人最近研究了一种操作:求一个字串两个后缀的公共前缀.比方说,有这样一个字符串:madamimadam,我们将这个字符串的各个字符予以标号:序号: 1 2 3 4 5 6 7 8 9 10 ...
- BZOJ1014[JSOI2008]火星人prefix(splay维护hash)
Description 火星人最近研究了一种操作:求一个字串两个后缀的公共前缀.比方说,有这样一个字符串:madamimadam,我们将这个字符串的各个字符予以标号:序号: 1 2 3 4 5 6 7 ...
- BZOJ1014: [JSOI2008]火星人prefix(splay 二分 hash)
题意 题目链接 Sol 一眼splay + 二分hash,不过区间splay怎么写来着呀 试着写了两个小时发现死活不对 看了一下yyb的代码发现自己根本就不会splay.... // luogu-ju ...
- [BZOJ1014] [JSOI2008] 火星人prefix (splay & 二分答案)
Description 火星人最近研究了一种操作:求一个字串两个后缀的公共前缀.比方说,有这样一个字符串:madamimadam,我们将这个字符串的各个字符予以标号:序号: 1 2 3 4 5 6 7 ...
- [bzoj1014](JSOI2008)火星人 prefix (Splay维护哈希)
Description 火星人最近研究了一种操作:求一个字串两个后缀的公共前缀. 比方说,有这样一个字符串:madamimadam,我们将这个字符串的各个字符予以标号:序号: 1 2 3 4 5 6 ...
随机推荐
- python的小知识点
python中的变量的名字必须由字母.数字.下划线组成,并且不可以以数字开头. 字典的内容是键-值对,键必须是不可变的,比如字符,整数,浮点数,元组,列表不可以,因为列表可变.集合的元素不重复.字典和 ...
- Android窗口系统第二篇---Window的添加过程
以前写过客户端Window的创建过程,大概是这样子的.我们一开始从Thread中的handleLaunchActivity方法开始分析,首先加载Activity的字节码文件,利用反射的方式创建一个Ac ...
- html5--1.9 img元素嵌入图片
html5--1.9 img元素嵌入图片 学习要点: img元素嵌入图片学习一个新属性:title 1.img的属性 1.src:必要属性,制定图片来源的路径; 2.alt属性:当图片无法显示时的替代 ...
- idea创建maven-archetype-webapp项目无java目录
使用idea创建一个maven-archetype-webapp项目 查看项目的目录结构,在main的目录下没有java目录 在main目录下创建java目录 使用快捷键 ctrl+alt+shift ...
- Ubuntu更改启动内存
参考:https://superuser.com/questions/152921/how-to-boot-with-mem-1024m-argument-using-grub-ubuntu-10-0 ...
- 第十四章-MySQL
1 安装 MySQL常见的版本 GA: 广泛使用的版本 RC: 最接近正式版本 Alpha和Bean: 内测版本和公测版本 有两种安装方式: 安装包和压缩包 1) 安装msi文件 2) 解压zip文件 ...
- linux 进程学习笔记-进程pipe管道
所谓“进程间通信(IPC,inter-process communication)”,按照其目的讲就是让进程之间能够“共享数据”,“传输数据”,“事件通知”等,我所知道的一共有“管道” “信号” “消 ...
- MFC默认窗口类名称
// special AFX window class name mangling #ifndef _UNICODE #define _UNICODE_SUFFIX #else #define _UN ...
- Gym:101630J - Journey from Petersburg to Moscow(最短路)
题意:求1到N的最短路,最短路的定义为路径上最大的K条边. 思路:对于每种边权,假设为X,它是第K大,那么小于X的变为0,大于K的,边权-X.然后求最短路,用dis[N]+K*X更新答案. 而小于K的 ...
- 休假回来 更博-MySQL以月为单位的客户综合情况表_20161008
十一休假老家事比较多 未来得及更新 今起依旧更博- 生成一个以用户ID为单位,各月下单天次,各月买了几个产品,各月订单额 ,天次,,天次,,天次,NULL)) AS 9月天次 FROM ( SELEC ...