bzoj1503,懒得复制,戳我戳我

Solution:

  • 我知不知道我是那根筋抽了突然来做splay,调了起码\(3h+\),到第二天才改出来(我好菜啊),当做训练调错吧
  • 一个裸的splay,没啥好说的

Attention:

  • 我的del操作里面,注意连边要把儿子的父亲更改,父亲的儿子更改,并且注意\(update\)
void del(int x){
ins(x);
int now=root;
if(ls(now))ans+=node[ls(now)].siz;
if(node[now].cnt==1){connect(rs(now),0,1);update(root);}/////这个地方
else {node[now].cnt--;node[now].ch[0]=0;node[ls(now)].fa=0;update(now);}////这个地方
return;
}
  • 然后就是求rk时,先运行了一遍del,但是now存的root值是之前的,找了贼久才找到这个错

之前的

int rk(int x){
int now=root;del(low);

之后的

int rk(int x){
del(low);int now=root;
if(x>node[now].siz)return -1;
while(1){
pushdown(now);
if(!now)return -1;
if(node[rs(now)].siz>=x){now=node[now].ch[1];}
else if(node[rs(now)].siz+node[now].cnt>=x){Splay(now,root);return node[now].val;}
else {x-=(node[rs(now)].siz+node[now].cnt);now=node[now].ch[0];}
}
}

Code:

//It is coded by Ning_Mew on 5.8
#include<bits/stdc++.h>
#define rs(x) node[x].ch[1]
#define ls(x) node[x].ch[0]
#define fa(x) node[x].fa
#define root node[0].ch[1]
using namespace std; const int maxn=1e5+10007; int n,low,tot=0,ans=0;
struct Node{
int fa,ch[2],val,cnt,siz,lazy;
}node[maxn]; void update(int x){node[x].siz=node[ls(x)].siz+node[rs(x)].siz+node[x].cnt;}
void connect(int x,int fa,int how){node[x].fa=fa;node[fa].ch[how]=x;}
int ident(int x){return x==node[fa(x)].ch[0]?0:1;}
void pushdown(int x){
if(node[x].lazy){
int lz=node[x].lazy;node[x].lazy=0;
if(ls(x))node[ls(x)].val+=lz,node[ls(x)].lazy+=lz;
if(rs(x))node[rs(x)].val+=lz,node[rs(x)].lazy+=lz;return;
}
}
void rorate(int x){
int Y=fa(x),R=fa(Y);int Yson=ident(x),Rson=ident(Y);
pushdown(Y);pushdown(x);
connect(node[x].ch[Yson^1],Y,Yson);
connect(Y,x,Yson^1);
connect(x,R,Rson);
update(Y);update(x);
}
void Splay(int x,int goal){
goal=fa(goal);
while(fa(x)!=goal){
if(fa(fa(x))==goal)rorate(x);
else if(ident(x)==ident(fa(x)))rorate(fa(x)),rorate(x);
else rorate(x),rorate(x);
}return;
}
int newnode(int x,int fa){node[++tot].val=x;node[tot].siz=node[tot].cnt=1;node[tot].fa=fa;return tot;}
void ins(int x){
int now=root;
if(!now){newnode(x,0);root=tot;return;}
while(now){
node[now].siz++;pushdown(now);
if(node[now].val==x){node[now].cnt++;Splay(now,root);/*root=now;*/return;}
int nxt=x<node[now].val?0:1;
if(!node[now].ch[nxt]){int pl=newnode(x,now);node[now].ch[nxt]=pl;Splay(pl,root);/*root=pl;*/return;}
now=node[now].ch[nxt];
}
}
void pr(int now){
if(!now)return;
cout<<"pr:"<<now<<' '<<node[now].siz<<' '<<node[now].val<<' '<<node[ls(now)].val<<' '<<node[rs(now)].val<<' '<<node[now].cnt<<endl;
pr(ls(now));pr(rs(now));//update(now);
}
void del(int x){
ins(x);
int now=root;
if(ls(now))ans+=node[ls(now)].siz;
if(node[now].cnt==1){
connect(rs(now),0,1);update(root);
}
else {node[now].cnt--;node[now].ch[0]=0;node[ls(now)].fa=0;update(now);}
return;
}
int rk(int x){
del(low);int now=root;
if(x>node[now].siz)return -1;
while(1){
pushdown(now);
if(!now)return -1;
if(node[rs(now)].siz>=x){now=node[now].ch[1];}
else if(node[rs(now)].siz+node[now].cnt>=x){Splay(now,root);return node[now].val;}
else {x-=(node[rs(now)].siz+node[now].cnt);now=node[now].ch[0];}
}
}
int main(){
scanf("%d%d",&n,&low);
int x;char ch;
for(int i=1;i<=n;i++){
cin>>ch;scanf("%d",&x);
if(ch=='I'){if(x<low)continue;ins(x);}
if(ch=='A'){node[root].val+=x;node[root].lazy+=x;}
if(ch=='S'){node[root].val-=x;node[root].lazy-=x;del(low);}
if(ch=='F'){printf("%d\n",rk(x));}
}
printf("%d\n",ans);
return 0;
}

【题解】 bzoj1503: [NOI2004]郁闷的出纳员 (Splay)的更多相关文章

  1. BZOJ1503 [NOI2004]郁闷的出纳员 splay

    原文链接http://www.cnblogs.com/zhouzhendong/p/8086240.html 题目传送门 - BZOJ1503 题意概括 如果某一个员工的工资低于了min,那么,他会立 ...

  2. bzoj1503[NOI2004]郁闷的出纳员——Splay

    题目:https://www.lydsy.com/JudgeOnline/problem.php?id=1503 好奇怪呀!为什么而TLE? 各种修改终于卡时过了.可是大家比我快多了呀?难道是因为自己 ...

  3. [BZOJ1503][NOI2004]郁闷的出纳员

    [BZOJ1503][NOI2004]郁闷的出纳员 试题描述 OIER公司是一家大型专业化软件公司,有着数以万计的员工.作为一名出纳员,我的任务之一便是统计每位员工的工资.这本来是一份不错的工作,但是 ...

  4. BZOJ 1503: [NOI2004]郁闷的出纳员 splay

    1503: [NOI2004]郁闷的出纳员 Description OIER公司是一家大型专业化软件公司,有着数以万计的员工.作为一名出纳员,我的任务之一便是统计每位员工的工资.这本来是一份不错的工作 ...

  5. [BZOJ1503][NOI2004]郁闷的出纳员 无旋Treap

    1503: [NOI2004]郁闷的出纳员 Time Limit: 5 Sec  Memory Limit: 64 MB Description OIER公司是一家大型专业化软件公司,有着数以万计的员 ...

  6. bzoj1503: [NOI2004]郁闷的出纳员(伸展树)

    1503: [NOI2004]郁闷的出纳员 题目:传送门 题解: 修改操作一共不超过100 直接暴力在伸展树上修改 代码: #include<cstdio> #include<cst ...

  7. bzoj1503 [NOI2004]郁闷的出纳员(名次树+懒惰标记)

    1503: [NOI2004]郁闷的出纳员 Time Limit: 5 Sec  Memory Limit: 64 MBSubmit: 8705  Solved: 3027[Submit][Statu ...

  8. NOI2004 郁闷的出纳员 Splay

    郁闷的出纳员 [问题描述] OIER公司是一家大型专业化软件公司,有着数以万计的员工.作为一名出纳员,我的任务之一便是统计每位员工的工资.这本来是一份不错的工作,但是令人郁闷的是,我们的老板反复无常, ...

  9. 【BZOJ1503】 [NOI2004]郁闷的出纳员 splay

    splay模板题,都快把我做忧郁了. 由于自己调两个坑点. 1.删除时及时updata 2.Kth 考虑k满足该点的条件即r->ch[1]->size+1<=k && ...

随机推荐

  1. Linux内核RPC请求过程

    这篇文章讲讲server端RPC报文的处理流程.server端RPC报文的处理函数是svc_process,这个函数位于net/sunrpc/svc.c中.这个函数须要一个svc_rqst结构的指针作 ...

  2. c# 淘宝运单查询

    using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.W ...

  3. 2017-2018-2 『网络对抗技术』Exp2:后门原理与实践

    1. 后门原理与实践实验说明及预备知识 一.实验说明 任务一:使用netcat获取主机操作Shell,cron启动 (0.5分) 任务二:使用socat获取主机操作Shell, 任务计划启动 (0.5 ...

  4. 【Java框架型项目从入门到装逼】第十一节 用户新增之把数据传递到后台

    让我们继续来做"主线任务",这一节,我们来做具体的用户新增功能.首先,为了简单起见,我把主页面改了一些,改的是列表那一块.删去了一些字段,和数据库表对应一致: 现在,我们要实现一个 ...

  5. 微信小程序 倒计时

    这两天在看微信小程序,参考了网上的资料,做了一个倒计时的练习,记录如下. 本文作者:罗兵 原地址:https://www.cnblogs.com/hhh5460/p/9981064.html 0.效果 ...

  6. 【第八课】php-fpm.conf配置文件解析

    在discuz论坛的nginx配置文件当中,我们可以看到有一段php解析的配置,如下: location ~ \.php$ { try_files $uri = 404; fastcgi_pass 1 ...

  7. eclipse 最最最常用快捷键

    使用eclipse这么久,发现其跟PS一样,使用一些快捷键会有效率很多. 至此总结出以下每次打开eclipse基本都会用上的快捷键. 不熟悉这些快捷键,在实际编程中有意识使用的话对以后编码很有帮助. ...

  8. 您需要来自XXX的权限才能对此文件夹进行更改

    解决办法: cmd命令:del/f/s/q 文件夹

  9. 重新解读DDD领域驱动设计(一)

    回顾 十年前,还未踏入某校时,便听闻某学长一毕业就入职北京某公司,月薪过万.对于一个名不见经传的小学院,一毕业能拿到这个薪水还是非常厉害的.听闻他学生期间参与开发了一款股票软件,股票那时正迎来一波疯涨 ...

  10. 软件测试_测试工具_APP测试工具_对比

    以下是我自己整理的APP测试工具对比,各个工具相关并不全面.尤其关于收费一项,我只是针对自己公司的实际情况进行对比的,每个工具还有其他收费套餐可以选择,详情可进入相关官网进行查看 以下是部分官网链接: ...