题解:

平衡树维护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. 转载:UML学习(二)-----类图(silent)

    原文:http://www.cnblogs.com/huiy/p/8552607.html 1.什么是类图 类图(Class diagram)主要用于描述系统的结构化设计.类图也是最常用的UML图,用 ...

  2. 【原创】大叔经验分享(32)docker挂载文件修改生效

    docker经常需要挂载文件到容器中,比如启动nginx # docker run -d --name test_nginx -v /tmp/nginx.conf:/etc/nginx/nginx.c ...

  3. JGroups

    JGroups Developer(s) Bela Ban Stable release 4.0.10.Final / February 1, 2018 Written in Java Operati ...

  4. Linux IO实时监控iostat命令

    简介 iostat主要用于监控系统设备的IO负载情况,iostat首次运行时显示自系统启动开始的各项统计信息,之后运行iostat将显示自上次运行该命令以后的统计信息.用户可以通过指定统计的次数和时间 ...

  5. 金九银十中,看看这31道Android面试题

    阅读目录 1.如何对 Android 应用进行性能分析 2.什么情况下会导致内存泄露 3.如何避免 OOM 异常 4.Android 中如何捕获未捕获的异常 5.ANR 是什么?怎样避免和解决 ANR ...

  6. swift 学习- 16 -- 构造过程 02

    // 类的继承 和 构造过程 // 类里面的所有的存储型属性 -- 包括所有继承自父类的属性 -- 都必须在构造过程中设置初始值 // Swift  为类类型提供了 两种构造器来确保实例中所有的存储属 ...

  7. Java的家庭记账本程序(D)

    日期:2019.2.8 博客期:031 星期一 今天是把程序的查询功能以列表的形式完成了! 截图如下:

  8. 好用的JS拖拽插件

    下载artDialog插件的时候发现它把拖拽单独封装成了一个方法,挺好用的,使用方法如下... 第一种拖拽方式-点击容器指定区域进行拖拽 $('.ui-dialog').on(DragEvent.ty ...

  9. 正则化 L1 L2

    机器学习中几乎都可以看到损失函数后面会添加一个额外项,常用的额外项一般有两种,一般英文称作ℓ1ℓ1-norm和ℓ2ℓ2-norm,中文称作L1正则化和L2正则化,或者L1范数和L2范数. L1正则化和 ...

  10. kali访问宿主机Web页面解决方案

    1.首先安装好PHPDVWA测试平台,将等级设置成low,kali中自带了python2.7.为了不再宿主机中修改python3.6,所以要利用kali来模访问宿主机中的Web页面.如果不进行配置修改 ...