正解:$splay$

解题报告:

传送门!

依然先考虑要呲呲些什么操作鸭$QwQ$

其实就只要一个删除区间,一个查询第$k$大,还一个插入就欧克?

删除区间的话直接旋转下根什么的然后直接把子树删了就好$QwQ$

查询第$k$大和$insert$是基操不说$QwQ$

然后还一个就集体扣除工资?本来一般这种还要考虑加个$ad[]$的$tag$,,,但因为这题太水了$QwQ$所以所有$add$操作的对象都是全员鸭$QwQ$所以直接开个变量记录所有人的修改就成,然后删除区间和$insert$的值相应改点儿就好$QwQ$

$over$,,,?

#include<bits/stdc++.h>
using namespace std;
#define il inline
#define ll long long
#define gc getchar()
#define ri register int
#define rc register char
#define rb register bool
#define rp(i,x,y) for(ri i=x;i<=y;++i)
#define my(i,x,y) for(ri i=x;i>=y;--i) const int N=+,inf=1e9;
int n,mm,ad,peo,as,rt,nod_cnt;
bool gdgs=;
struct node{int ch[],fa,val,cnt,sz;il void pre(ri x,ri fat){ch[]=ch[]=;fa=fat;val=x;cnt=sz=;}}tr[N]; il int read()
{
rc ch=gc;ri x=;rb y=;
while(ch!='-' && (ch>'' || ch<''))ch=gc;
if(ch=='-')ch=gc,y=;
while(ch>='' && ch<='')x=(x<<)+(x<<)+(ch^''),ch=gc;
return y?x:-x;
}
il char rd(){rc ch=gc;while(ch!='I' && ch!='A' && ch!='S' && ch!='F')ch=gc;return ch;}
il void pushup(ri x){tr[x].sz=tr[tr[x].ch[]].sz+tr[tr[x].ch[]].sz+tr[x].cnt;}
il void rotate(ri x)
{
ri fa=tr[x].fa,grdfa=tr[fa].fa;bool op1=tr[fa].ch[]==x,op2=tr[grdfa].ch[]==fa;
tr[grdfa].ch[op2]=x;tr[x].fa=grdfa;
tr[fa].ch[op1]=tr[x].ch[op1^];tr[tr[x].ch[op1^]].fa=fa;
tr[fa].fa=x;tr[x].ch[op1^]=fa;
pushup(fa);pushup(x);
}
il void splay(ri x,ri goal)
{
while(tr[x].fa!=goal)
{
ri fa=tr[x].fa,grdfa=tr[fa].fa;
if(grdfa!=goal)(tr[fa].ch[]==x)^(tr[grdfa].ch[]==fa)?rotate(x):rotate(fa);
rotate(x);
}
if(!goal)rt=x;
}
il void insert(ri x)
{
ri nw=rt,fa=;
while(nw && tr[nw].val!=x)fa=nw,nw=tr[nw].ch[x>tr[nw].val];//,printf("nw=%d\n",nw);
if(nw){++tr[nw].cnt;splay(nw,);return;}
nw=++nod_cnt;if(fa)tr[fa].ch[x>tr[fa].val]=nod_cnt;tr[nw].pre(x,fa);
splay(nw,);
}
il void fd(ri x)
{
ri nw=rt;if(!nw)return;
while(tr[nw].ch[tr[nw].val<x] && tr[nw].val!=x)nw=tr[nw].ch[tr[nw].val<x];
splay(nw,);
}
il int ask_val(ri x)
{
if(x<= || tr[rt].sz<x)return --ad;
ri nw=rt;
while(gdgs)
{
if(tr[nw].cnt+tr[tr[nw].ch[]].sz<x)x-=tr[tr[nw].ch[]].sz+tr[nw].cnt,nw=tr[nw].ch[];
else if(tr[tr[nw].ch[]].sz>=x)nw=tr[nw].ch[];
else return tr[nw].val;
}
}
il int ask_lst(ri x)
{
fd(x);ri nw=tr[rt].ch[];
if(tr[rt].val>=x)return rt;
while(tr[nw].ch[])nw=tr[nw].ch[];
return nw;
}
il void delet(ri x)
{
ri nw=ask_lst(mm-ad);
splay(nw,);
as+=tr[tr[rt].ch[]].sz;peo-=tr[tr[rt].ch[]].sz;
tr[tr[rt].ch[]].sz=tr[tr[rt].ch[]].cnt=;
tr[rt].ch[]=;
tr[].sz=;
pushup(rt);
} int main()
{
n=read();mm=read();insert(inf);
while(n--)
{
rc ch=rd();ri x=read();
switch(ch)
{
case 'I':if(x>=mm)insert(x-ad),++peo;break;
case 'A':ad+=x;break;
case 'S':ad-=x;delet(mm-ad);break;
case 'F':printf("%d\n",ask_val(peo-x+)+ad);break;
}
}
printf("%d\n",as);
return ;
}

随机推荐

  1. C++笔记:面向对象编程(Handle类)

    句柄类 句柄类的出现是为了解决用户使用指针时须要控制指针的载入和释放的问题. 用指针訪问对象非常easy出现悬垂指针或者内存泄漏的问题. 为了解决这些问题,有很多方法能够使用,句柄类就是当中之中的一个 ...

  2. part11-LED驱动程序设计-part11.1-字符设备控制

  3. 威胁快报|新兴挖矿团伙借助shodan作恶,非web应用安全再鸣警钟

    近日,阿里云安全发现了一个使用未授权访问漏洞部署恶意Docker镜像进行挖矿的僵尸网络团伙.我们给这一团伙取名为Xulu,因为该团伙使用这个字符串作为挖矿时的用户名. Xulu并不是第一个攻击Dock ...

  4. console.log详细介绍

    console.log详细介绍 效果图: 代码如下: console.log("%c hello world!:http://www.baidu.com","color: ...

  5. Laravel 之搜索引擎elasticsearch扩展Scout

    简介 Laravel Scout 是针对Eloquent 模型开发的一个简单的,基于驱动的全文检索系统.Scout 使用模型观察者时会自动保持你的检索索引与你的 Eloquent 记录同步. 目前,S ...

  6. SuperSocket获取会话的连接和断开事件

    关键字: 连接事件, 断开事件, OnSessionStarted,OnSessionClosed, NewSessionConnected, SessionClosed AppSession 的虚方 ...

  7. redux【react】

    首先介绍一下redux就是Flux的一种进阶实现.它是一个应用数据流框架,主要作用应用状态的管理 一.设计思想: (1).web应用就是一个状态机,视图和状态一一对应 (2).所有的状态保存在一个对象 ...

  8. 深入Java线程管理(五):线程池

    这几天主要是狂看源程序,在弥补了一些以前知识空白的同时,也学会了不少新的知识(比如 NIO),或者称为新技术吧. 线程池就是其中之一,一提到线程,我们会想到以前<操作系统>的生产者与消费者 ...

  9. C#的选择语句练习(一)

    1.请输入一个数x,若x<1,则y=x:若1<=x<10,则y=2x-1:若x>=10,则y=3x-11,要求随意输入一个x值,求出y值. 2.输入问题[你有房子吗?],若回答 ...

  10. H3C 配置高级ACL