题解:

平衡树维护hash值

为了支持加入删除操作 x*base^y 其中y为他是第k大

同一般的维护方法,我们不用对每个节点维护他的hash值

而是只用记录他的x值(他的位置) 然后通过updata的时候维护

很神奇的一点是

我用了mo数就炸了。。。

直接自然溢出就好了。。。应该是哪里正负没处理好。。

另外还wa了一个点。。

代码:

#include <bits/stdc++.h>
using namespace std;
#define ll long long
const ll N=5e5+;
const ll Base=;
ll n,m,q,cl[N],a[N],b[N];
map<ll,ll> M;
struct Splay{
ll count2[N],data[N],ls[N],rs[N],fa[N],v[N],vv[N],root=,cnt=;
void updata(ll x)
{
count2[x]=count2[ls[x]]+count2[rs[x]]+;
data[x]=(data[ls[x]]+1ll*data[rs[x]]*cl[count2[ls[x]]+]
+cl[count2[ls[x]]]*v[x]);
}
void rotate(ll x,ll y)
{
ll fa1=fa[x];
if (y==)
{
rs[fa1]=ls[x];
if (ls[x]) fa[ls[x]]=fa1;
} else
{
ls[fa1]=rs[x];
if (rs[x]) fa[rs[x]]=fa1;
}
fa[x]=fa[fa1];
if (fa[fa1])
{
ls[fa[fa1]]==fa1?ls[fa[fa1]]=x:rs[fa[fa1]]=x;
}
fa[fa1]=x;
if (y==) ls[x]=fa1; else rs[x]=fa1;
updata(fa1); updata(x);
}
void splay(ll x,ll goal)
{
ll fa1=fa[x];
while (fa1!=goal)
{
if (fa[fa1]==goal)
x==ls[fa1]?rotate(x,):rotate(x,);
else
if (fa1==ls[fa[fa1]])
if (x==ls[fa1]) rotate(fa1,),rotate(x,);
else rotate(x,),rotate(x,);
else
if (x==rs[fa1]) rotate(fa1,),rotate(x,);
else rotate(x,),rotate(x,);
fa1=fa[x];
}
if (!goal) root=x;
}
ll search(ll goal)
{
ll x=root;
while (x)
{
if (vv[x]==goal) return(x);
if (vv[x]<goal) x=rs[x];
else x=ls[x];
}
}
void ins(ll y,ll x1)
{
ll x=root;
while (x)
{
if (y>vv[x])
if (rs[x]) x=rs[x]; else break;
else
if (ls[x]) x=ls[x]; else break;
}
if (!x) root=++cnt;
else
{
if (y>vv[x])
{
rs[x]=++cnt; fa[cnt]=x;
} else
{
ls[x]=++cnt; fa[cnt]=x;
}
}
vv[cnt]=y; v[cnt]=x1; count2[cnt]=;
splay(cnt,);
}
void del(ll x1)
{
ll x=search(x1);
splay(x,);
if (!ls[x])
{
root=rs[root]; fa[root]=; return;
}
ll y=ls[x];
while (rs[y]) y=rs[y];
rs[y]=rs[x];
if (rs[y]) fa[rs[y]]=y;
updata(y);
root=ls[x]; fa[ls[x]]=; splay(y,);
}
}A,B;
int main()
{
freopen("1.in","r",stdin);
freopen("1.out","w",stdout);
ios::sync_with_stdio(false);
cl[]=;
for (ll i=;i<N;i++) cl[i]=(1ll*cl[i-]*Base);
cin>>n>>m>>q;
ll cnt=;
for (ll i=;i<m;i++) cnt+=cl[i];
for (ll i=;i<=n;i++) cin>>a[i];
for (ll i=;i<=m;i++) A.ins(a[i],i);
++M[A.data[A.root]];
for (ll i=m+;i<=n;i++)
{
A.del(a[i-m]); A.ins(a[i],i);
ll tmp=A.data[A.root]-1ll*cnt*(i-m);
++M[tmp];
}
for (ll i=;i<=m;i++)
{
cin>>b[i];
B.ins(b[i],i);
}
for (ll i=;i<=q;i++)
{
ll x,y;
cin>>x>>y;
B.del(b[x]);
b[x]=y;
B.ins(y,x);
cout<<M[B.data[B.root]]<<endl;
}
return ;
}

P4715 「英语」Z 语言的更多相关文章

  1. [Luogu4715]「英语」Z 语言

    luogu description 你有一个长度为\(n\)的串\(A\)和一个长度为\(m\)的串\(B\),字符集大小\(2^{31}\),且同一个串中没有相同的元素. 定义\(B\)串与\(A_ ...

  2. 「HNOI2004」「LuoguP2292」L语言(AC自动机

    题目描述 标点符号的出现晚于文字的出现,所以以前的语言都是没有标点的.现在你要处理的就是一段没有标点的文章. 一段文章T是由若干小写字母构成.一个单词W也是由若干小写字母构成.一个字典D是若干个单词的 ...

  3. Python文字转换语音,让你的文字会「说话」,抠脚大汉秒变撒娇萌妹

    作者 | pk 哥 来源公众号 | Python知识圈(ID:PythonCircle) APP 也有文字转换为语音的功能,虽然听起来很别扭,但是基本能解决长辈们看不清文字或者眼睛疲劳,通过文字转换为 ...

  4. 【LOJ】#3046. 「ZJOI2019」语言

    LOJ#3046. 「ZJOI2019」语言 先orz zsy吧 有一个\(n\log^3n\)的做法是把树链剖分后,形成logn个区间,这些区间两两搭配可以获得一个矩形,求矩形面积并 然后就是对于一 ...

  5. 「ZJOI2019」语言 解题报告

    「ZJOI2019」语言 3个\(\log\)做法比较简单,但是写起来还是有点麻烦的. 大概就是树剖把链划分为\(\log\)段,然后任意两段可以组成一个矩形,就是个矩形面积并,听说卡卡就过去了. 好 ...

  6. 正则表达式从入门到放弃「Java」

    正则表达式能做什么? 正则表达式可以用来搜索.编辑或处理文本. 「都懂它可以处理文本,可到底是怎么回事?」 正则表达式的定义 百度百科:正则表达式是对字符串操作的一种逻辑公式,就是用事先定义好的一些特 ...

  7. 「MoreThanJava」当大学选择了计算机之后应该知道的

    「MoreThanJava」 宣扬的是 「学习,不止 CODE」,本系列 Java 基础教程是自己在结合各方面的知识之后,对 Java 基础的一个总回顾,旨在 「帮助新朋友快速高质量的学习」. 当然 ...

  8. 面试都在问的「微服务」「RPC」「服务治理」「下一代微服务」一文带你彻底搞懂!

    ❝ 文章每周持续更新,各位的「三连」是对我最大的肯定.可以微信搜索公众号「 后端技术学堂 」第一时间阅读(一般比博客早更新一到两篇) ❞ 单体式应用程序 与微服务相对的另一个概念是传统的「单体式应用程 ...

  9. 「MoreThanJava」计算机系统概述

    「MoreThanJava」 宣扬的是 「学习,不止 CODE」,本系列 Java 基础教程是自己在结合各方面的知识之后,对 Java 基础的一个总回顾,旨在 「帮助新朋友快速高质量的学习」. 当然 ...

随机推荐

  1. 谈谈asp,php,jsp的优缺点

    谈谈asp,php,jsp的优缺点   http://hi.baidu.com/lhyboy/item/f95bac264c38830d72863e41 asp.php.asp.net.jsp等主流网 ...

  2. Unity3D之Mesh(四)绘制多边形

    来自https://www.cnblogs.com/JLZT1223/p/6086191.html 1. 总的来说绘制平面的思想十分简单,就是将需要的平面拆分成几个三角形然后进行绘制就可以啦,主要的思 ...

  3. deque-->collections之#双向消息队列

    deque 双向队列单项队列 方法: append #往右边添加一个appendleft #左边添加clear #清空队列count #看看这个队列里某个元素出现了多少次extend #从右边多个元素 ...

  4. 010_mac常用docker维护命令

    一. ➜ ~ docker search rabbitmq #搜索 NAME DESCRIPTION STARS OFFICIAL AUTOMATED rabbitmq RabbitMQ is an ...

  5. elasticsearch5.0.1集群排错的几个思路总结

    1.首先查看集群整体健康状态 # curl -XGET http://10.27.35.94:9200/_cluster/health?pretty { "cluster_name" ...

  6. PHP IDE选择标准

    2017年11月17日09:35:01 这里记录一下PHP IDE的选择标准 1.  是否有错误提示, 对于一些 `缺少分号`, `花括号不配对`, `变量未定义就使用`等待的提示是要有的 2. 代码 ...

  7. [C]gcc编译器的一些常用语法

    简单的GCC语法: 如果你只有一个文件(或者只有几个文件),那么就可以不写Makefile文件(当然有Makefile更加方便),用gcc直接编译就行了.在这里我们只介绍几个我经常用的几个参数,第一是 ...

  8. IntellJ IDEA下写JUnit

     安装配置JUnit  File->Settings->Plugins->Browse Repositories->在右侧搜索框输入"junit"-> ...

  9. 来,了解一下Java内存模型(JMM)

    网上有很多关于Java内存模型的文章,在<深入理解Java虚拟机>和<Java并发编程的艺术>等书中也都有关于这个知识点的介绍.但是,很多人读完之后还是搞不清楚,甚至有的人说自 ...

  10. Confluence 6 SQL Server 问题解决

    如果你收到了下面的错误信息,检查你给出的 confluenceuser 用户具有所有需要的数据库权限,当你使用 localhost 进行连接的时候. Could not successfully te ...