[SHOI2009] 会场预约
Description
题意:支持操作:
- 按顺序在数轴上插入一条线段,删除并询问所有与这条线段有交的线段个数。
- 询问当前数轴上一共有多少条线段。
Solution
想做了很久的题=。=
观察到和线段\([l_i,r_i]\)有交的线段,实际上就是右端点\(\ge l_i\)并且左端点\(\le r_i\) 的一些线段。我们可以把所有线段按照右端点第一关键字,左端点第二关键字放进一个Treap里。然后每次查询当前插入的这条线段的后继,即第一个右端点\(\ge l_i\)的线段。如果它们有交,就删掉这个线段,然后继续判断,否则\(break\)掉就行了。
似乎可以线段树染色做?
Code
#include<set>
#include<map>
#include<queue>
#include<cctype>
#include<vector>
#include<cstdio>
#include<cstring>
#include<iostream>
#include<algorithm>
using std::min;
using std::max;
using std::swap;
typedef double db;
const int N=200005;
typedef long long ll;
#define pb(A) push_back(A)
#define pii std::pair<int,int>
#define mp(A,B) std::make_pair(A,B)
int l[N],r[N];
int n,tot,root;
int ch[N][2],sze[N];
int prio[N],val[N],id[N];
void pushup(int cur){
sze[cur]=sze[ch[cur][0]]+sze[ch[cur][1]]+1;
}
void rotate(int &cur,int d){
int x=ch[cur][d],y=ch[x][d^1];
ch[cur][d]=y;ch[x][d^1]=cur;
pushup(cur);pushup(x);cur=x;
}
void insert(int &cur,int x,int idx){
if(!cur){
cur=++tot;
val[cur]=x;id[cur]=idx;
sze[cur]=1;prio[cur]=rand();return;
} sze[cur]++;
int d=val[cur]<x or val[cur]==x and l[id[cur]]<l[idx];
insert(ch[cur][d],x,idx);
if(prio[ch[cur][d]]<prio[cur]) rotate(cur,d);
}
void remove(int &cur,int x,int idx){
if(val[cur]==x){
if(!ch[cur][0] or !ch[cur][1]){
cur=ch[cur][0]+ch[cur][1];
return;
} if(prio[ch[cur][0]]<prio[ch[cur][1]])
rotate(cur,0),remove(ch[cur][1],x,idx);
else rotate(cur,1),remove(ch[cur][0],x,idx);
pushup(cur);return;
}
int d=val[cur]<x or val[cur]==x and l[id[cur]]<l[idx];
remove(ch[cur][d],x,idx);
pushup(cur);
}
const int inf=0x3f3f3f3f;
int nxt(int cur,int x){
if(!cur) return inf;
if(val[cur]<x) return nxt(ch[cur][1],x);
int p=nxt(ch[cur][0],x);
if(p!=inf) return p;
return id[cur];
}
int getint(){
int X=0,w=0;char ch=0;
while(!isdigit(ch))w|=ch=='-',ch=getchar();
while( isdigit(ch))X=X*10+ch-48,ch=getchar();
if(w) return -X;return X;
}
signed main(){
srand(20020619);
n=getint();
for(int i=1;i<=n;i++){
char ch[10];scanf("%s",ch);
if(ch[0]=='A'){
l[i]=getint(),r[i]=getint();
int p=nxt(root,l[i]),tot=0;
while(p!=inf and l[p]<=r[i]){
// printf("p=%d\n",p);
remove(root,r[p],p);
p=nxt(root,l[i]);tot++;
}
insert(root,r[i],i);
printf("%d\n",tot);
} else
printf("%d\n",sze[root]);
} return 0;
}
[SHOI2009] 会场预约的更多相关文章
- 【题解】P2161[SHOI2009]会场预约(set)
[题解][P2161 SHOI2009]会场预约 题目很像[[题解]APIO2009]会议中心 \(set\)大法好啊! 然后我们有个小\(trick\)(炒鸡帅),就是如何优雅地判断线段交? str ...
- [LuoguP2161[ [SHOI2009]会场预约 (splay)
题面 传送门:https://www.luogu.org/problemnew/show/P2161 Solution splay 的确有线段树/树状数组的做法,但我做的时候脑残没想到 我们可以考虑写 ...
- 2021.12.08 [SHOI2009]会场预约(平衡树游码表)
2021.12.08 [SHOI2009]会场预约(平衡树游码表) https://www.luogu.com.cn/problem/P2161 题意: 你需要维护一个 在数轴上的线段 的集合 \(S ...
- [SHOI2009] 会场预约 - Treap
Description PP大厦有一间空的礼堂,可以为企业或者单位提供会议场地.这些会议中的大多数都需要连续几天的时间(个别的可能只需要一天),不过场地只有一个,所以不同的会议的时间申请不能够冲突.也 ...
- BZOJ2028: [SHOI2009]会场预约(set)
Time Limit: 20 Sec Memory Limit: 64 MBSubmit: 425 Solved: 213[Submit][Status][Discuss] Description ...
- P2161 [SHOI2009]会场预约
题目描述 PP大厦有一间空的礼堂,可以为企业或者单位提供会议场地.这些会议中的大多数都需要连续几天的时间(个别的可能只需要一天),不过场地只有一个,所以不同的会议的时间申请不能够冲突.也就是说,前一个 ...
- P2161 [SHOI2009]会场预约 (线段树:线段树上的不重复覆盖数)
题目描述 PP大厦有一间空的礼堂,可以为企业或者单位提供会议场地.这些会议中的大多数都需要连续几天的时间(个别的可能只需要一天),不过场地只有一个,所以不同的会议的时间申请不能够冲突.也就是说,前一个 ...
- P2161 [SHOI2009]会场预约[线段树/树状数组+二分/STL]
题目描述 PP大厦有一间空的礼堂,可以为企业或者单位提供会议场地.这些会议中的大多数都需要连续几天的时间(个别的可能只需要一天),不过场地只有一个,所以不同的会议的时间申请不能够冲突.也就是说,前一个 ...
- LuoguP2161 [SHOI2009]会场预约
题目地址 题目链接 题解 用fhqtreap对区间进行维护. 可以注意到的是,对于当前存在的预约,他们一定是升序排列的(有重叠的都被删了). 那么就可以用按照位置分裂的fhqtreap搞了(预约无论按 ...
- Luogu2161 [SHOI2009]会场预约-线段树
Solution 线段树维护 sum 表示区间内预约个数, L 表示区间最左边的预约, R 表示区间最右边的预约. $pushup$ 就是这样 : void up(int nd) { sum[nd] ...
随机推荐
- assetBundle 中的prefeb资源图片显示粉色方框
assetBundle打包的资源是有平台属性的,当移动端iOS或者Android AssetBundle资源 在editor 加载的时候,比如TextMeshPro中的字体就不能正确加载 pc端调试, ...
- JavaScript 变量的作用域名
在JavaScript中,用var申明的变量实际上是有作用域的. 如果一个变量在函数体内部申明,则该变量的作用域为整个函数体,在函数体外不可引用该变量: 'use strict'; function ...
- Centos yum 修改为阿里源以及常用的命令
1.备份 mv /etc/yum.repos.d/CentOS-Base.repo /etc/yum.repos.d/CentOS-Base.repo.backup 2.下载新的CentOS-Base ...
- Nhibernate入门篇连接Sqlserver的增删查改
第一步:创建数据库 create table Emp( EmpId int primary key identity, EmpName ), EmpDate date ) 第二步:去官网下载:http ...
- App设计模式纵横谈(1)
对我的文章和培训课程感兴趣的可以加我微信16230091进行关注. —————————————————————————————————— 今天聊聊我沉淀比较久的一门技术,设计模式.这里是第一篇,算是概 ...
- three.js 微信小游戏
最近在 https://classroom.udacity.com/courses/cs291 学习了一些 3D 引擎和 three.js 的知识 把 three.js 弄到微信小游戏里,先随便跑一跑 ...
- js内存空间的那点事
由于js具有自动垃圾回收机制,导致接触js后一直没去关注js的内存分配及变量回收等原理,只是懵懂的了解用变量标记法(null)可以手动的去清除或是回收:是时候弥补这个大坑了... 垃圾回收两种方法 一 ...
- 《Opencv 3 计算机视觉 python语言实现》· 第二遍 —— 读后笔记
概览 代码实战 https://github.com/xinghalo/ml-in-action/tree/master/book-opencv
- so静态分析进阶练习——一个CreakeMe的分析思路
i春秋作家:HAI_ 原文来自:https://bbs.ichunqiu.com/thread-41371-1-1.html 说明 拿到一个CreakeMe,写一个分析思路.CreakMe主要是对.s ...
- web API简介(一):API,Ajax和Fetch
概述 今天逛MDN,无意中看到了web API简介,觉得挺有意思的,就认真读了一下. 下面是我在读的时候对感兴趣的东西的总结,供自己开发时参考,相信对其他人也有用. 什么是API API (Appli ...