M - 约会安排 HDU - 4553 线段树 (最长连续段)
中文题面
思路:维和两个区间 一个是女神区间 一个是基友区间 如果是基友要预约时间 直接在基友区间查询可满足的起点 (这里先判tree[1].m >=length也就是有没有这样的区间满足时间length) 预约成功后更新基友区间
如果是女神要预约区间 先在基友区间预约看有没有满足的区间 (同样看根节点的m) 如果有 同时更新两个区间 如果没有继续在女神区间查找 如果女神区间有 则同时更新基友和女神区间 如果没有 那就真没有了直接输出 题目要求的话
#include<bits/stdc++.h>
using namespace std;
const int maxn=1e6+;
struct Node{
int l,r;
int ml,mr,m;
}tree1[maxn*],tree2[maxn*];
void build(int x,int l,int r){
tree1[x].l=tree2[x].l=l;
tree1[x].r=tree2[x].r=r;
tree1[x].ml=tree2[x].ml=tree1[x].mr=tree2[x].mr=tree1[x].m=tree2[x].m=r-l+;
if(l==r)return ;
int mid=l+r>>;
build(x<<,l,mid);
build(x<<|,mid+,r);
}
void push_up(int x){
int mid=tree1[x].r+tree1[x].l>>;
tree1[x].ml=tree1[x<<].ml;
tree1[x].mr=tree1[x<<|].mr;
tree1[x].m=max(max(tree1[x<<].m,tree1[x<<|].m),tree1[x<<].mr+tree1[x<<|].ml);
if(tree1[x<<].ml==mid-tree1[x].l+)tree1[x].ml+=tree1[x<<|].ml;
if(tree1[x<<|].mr==tree1[x].r-mid)tree1[x].mr+=tree1[x<<].mr; tree2[x].ml=tree2[x<<].ml;
tree2[x].mr=tree2[x<<|].mr;
tree2[x].m=max(max(tree2[x<<].m,tree2[x<<|].m),tree2[x<<].mr+tree2[x<<|].ml);
if(tree2[x<<].ml==mid-tree2[x].l+)tree2[x].ml+=tree2[x<<|].ml;
if(tree2[x<<|].mr==tree2[x].r-mid)tree2[x].mr+=tree2[x<<].mr; }
void push_down(int x){
int mid=tree1[x].l+tree1[x].r>>;
if(tree1[x].m==tree1[x].r-tree1[x].l+){
tree1[x<<].ml=tree1[x<<].mr=tree1[x<<].m=mid-tree1[x].l+;
tree1[x<<|].ml=tree1[x<<|].mr=tree1[x<<|].m=tree1[x].r-mid;
}
else if(tree1[x].m==){
tree1[x<<].ml=tree1[x<<].mr=tree1[x<<].m=;
tree1[x<<|].ml=tree1[x<<|].mr=tree1[x<<|].m=;
} if(tree2[x].m==tree2[x].r-tree2[x].l+){
tree2[x<<].ml=tree2[x<<].mr=tree2[x<<].m=mid-tree2[x].l+;
tree2[x<<|].mr=tree2[x<<|].ml=tree2[x<<|].m=tree2[x].r-mid;
}
else if(tree2[x].m==){
tree2[x<<].ml=tree2[x<<].mr=tree2[x<<].m=;
tree2[x<<|].mr=tree2[x<<|].ml=tree2[x<<|].m=;
}
}
void update(int x,int l,int r,int value){
if(tree1[x].l>=l&&tree1[x].r<=r){
if(value==){
tree1[x].ml=tree1[x].mr=tree1[x].m=;
}
else if(value==){
tree1[x].ml=tree1[x].mr=tree1[x].m=;
tree2[x].ml=tree2[x].mr=tree2[x].m=;
}
else {
tree1[x].ml=tree1[x].mr=tree1[x].m=tree1[x].r-tree1[x].l+;
tree2[x].ml=tree2[x].mr=tree2[x].m=tree1[x].r-tree1[x].l+;
}
return ;
}
int mid=tree1[x].l+tree1[x].r>>;
push_down(x);
if(mid>=l)update(x<<,l,r,value);
if(mid<r)update(x<<|,l,r,value);
push_up(x);
}
int query(int x,int length,int value){
if(tree1[x].l==tree1[x].r)return tree1[x].l;
push_down(x);
int mid=tree1[x].l+tree1[x].r>>;
if(value==){
if(tree1[x<<].m>=length){
return query(x<<,length,value);
}
else if(tree1[x<<].mr+tree1[x<<|].ml>=length){
return mid-tree1[x<<].mr+;
}
else return query(x<<|,length,value);
}
else {
if(tree2[x<<].m>=length){
return query(x<<,length,value);
}
else if(tree2[x<<].mr+tree2[x<<|].ml>=length){
return mid-tree2[x<<].mr+;
}
else return query(x<<|,length,value);
}
}
int main(){
int t;
int kase=;
scanf("%d",&t);
char s[];
int temp;
int q;
int n;
while(t--){
printf("Case %d:\n",kase++);
scanf("%d%d",&n,&q);
build(,,n);
while(q--){
scanf("%s%d",s,&temp);
if(s[]=='D'){
if(tree1[].m>=temp){
int start=query(,temp,);
update(,start,start+temp-,);
printf("%d,let's fly\n",start);
}
else printf("fly with yourself\n");
}
else if(s[]=='N'){
if(tree1[].m>=temp){
int start=query(,temp,);
update(,start,start+temp-,);
printf("%d,don't put my gezi\n",start);
}
else if(tree2[].m>=temp){
int start=query(,temp,);
update(,start,start+temp-,);
printf("%d,don't put my gezi\n",start);
}
else printf("wait for me\n");
}
else {
int zz;
scanf("%d",&zz);
update(,temp,zz,);
printf("I am the hope of chinese chengxuyuan!!\n");
}
} }
return ;
}
M - 约会安排 HDU - 4553 线段树 (最长连续段)的更多相关文章
- HDU 3308 线段树 最长连续上升子序列 单点更新 区间查询
题意: T个测试数据 n个数 q个查询 n个数 ( 下标从0开始) Q u v 查询 [u, v ] 区间最长连续上升子序列 U u v 把u位置改成v #include<iostream> ...
- E - Tunnel Warfare HDU - 1540 F - Hotel G - 约会安排 HDU - 4553 区间合并
E - Tunnel Warfare HDU - 1540 对这个题目的思考:首先我们已经意识到这个是一个线段树,要利用线段树来解决问题,但是怎么解决呢,这个摧毁和重建的操作都很简单,但是这个查询怎么 ...
- 约会安排HDU - 4553
寒假来了,又到了小明和女神们约会的季节. 小明虽为屌丝级码农,但非常活跃,女神们常常在小明网上的大段发言后热情回复"呵呵",所以,小明的最爱就是和女神们约会.与此同时,也有很多基 ...
- 约会安排---hdu4553(线段树,麻烦的区间覆盖)
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=4553 算是poj3667的加强版,建立两颗线段树,一个是DS区间,另一个是NS区间.那么根据题意, ...
- 约会安排 HDU - 4553(线段树区间查询,区间修改,区间合并)
题目: 寒假来了,又到了小明和女神们约会的季节. 小明虽为屌丝级码农,但非常活跃,女神们常常在小明网上的大段发言后热情回复“呵呵”,所以,小明的最爱就是和女神们约会.与此同时,也有很多基友找他开黑, ...
- M - 约会安排 - hdu 4553
寒假来了,又到了小明和女神们约会的季节. 小明虽为�丝级码农,但非常活跃,女神们常常在小明网上的大段发言后热情回复“呵呵”,所以,小明的最爱就是和女神们约会.与此同时,也有很多基友找他开黑,由于数量 ...
- hdu 5877 线段树(2016 ACM/ICPC Asia Regional Dalian Online)
Weak Pair Time Limit: 4000/2000 MS (Java/Others) Memory Limit: 262144/262144 K (Java/Others)Total ...
- hdu 3974 线段树 将树弄到区间上
Assign the task Time Limit: 15000/5000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) ...
- hdu 3436 线段树 一顿操作
Queue-jumpers Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) To ...
随机推荐
- 显式与隐式(ExplicitAndImplicit)
显式与隐式(Explicit And Implicit) 1.概念 1.1 显式 实现的单词Explicit意思是清楚的.明确的.详述的.所以,显式的“显”是指明显且清楚的实现,相对于接口来说,就是明 ...
- 使用模块PIL 生成 随机验证码
--------------默认自己无能,无疑是给失败制造机会!你认为自己是什么样的人,就将成为什么样的人. 要使用PIL模块. 安装: 1 pip3 install pillow 基本使用 1. 创 ...
- CentOS 7从Python 2.7升级至Python3.6.1
引言: CentOS是目前最为流行的Linux服务器系统,其默认的Python 2.x,但是根据python社区的规划,在不久之后,整个社区将向Python3迁移,且将不在支持Python2, 那该如 ...
- 通过设置线程池的最小线程数来提高task的效率,SetMinThreads。
http://www.cnblogs.com/Charltsing/p/taskpoolthread.html task默认对线程的调度是逐步增加的,连续多次运行并发线程,会提高占用的线程数,而等若干 ...
- python文件读和写
fileHandle = open ( 'G:/qqfile/1.txt','w' )fileHandle.write('abcd')#写文件 地址要用反斜杠fileHandle.close() fi ...
- Mysql MyISAM与InnoDB 表锁行锁以及分库分表优化
一. 两种存储引擎:MyISAM与InnoDB 区别与作用 1. count运算上的区别: 因为MyISAM缓存有表meta-data(行数等),因此在做COUNT(*)时对于一个结构很好的查询是不需 ...
- Windows10 Build 18298 桌面显示计算机(此电脑)
- 解读event.returnValue和return false
前言 首先我们要清楚returnValue是IE的一个属性,如果设置了该属性,它的值比事件句柄的返回值优先级要高,把它的值设置为false,可以取消发生事件源元素的默认动作:return false就 ...
- Lumen与laravel的区别
Lumen与laravel的区别 困惑 一直都无法很友好的理解Lumen与Laravel之间的区别,只知道他们是非常相似的两个php框架,使用方法什么的都差不多. 为什么要解惑 最近接手了公司的一 ...
- redis4.X
tar -zxvf ****cd /redismakecd /srcmake install vi redis.confdaemonize yes mkdir /usr/local/redis/bin ...