中文题面

思路:维和两个区间  一个是女神区间 一个是基友区间  如果是基友要预约时间 直接在基友区间查询可满足的起点 (这里先判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 线段树 (最长连续段)的更多相关文章

  1. HDU 3308 线段树 最长连续上升子序列 单点更新 区间查询

    题意: T个测试数据 n个数 q个查询 n个数 ( 下标从0开始) Q u v 查询 [u, v ] 区间最长连续上升子序列 U u v 把u位置改成v #include<iostream> ...

  2. E - Tunnel Warfare HDU - 1540 F - Hotel G - 约会安排 HDU - 4553 区间合并

    E - Tunnel Warfare HDU - 1540 对这个题目的思考:首先我们已经意识到这个是一个线段树,要利用线段树来解决问题,但是怎么解决呢,这个摧毁和重建的操作都很简单,但是这个查询怎么 ...

  3. 约会安排HDU - 4553

    寒假来了,又到了小明和女神们约会的季节.  小明虽为屌丝级码农,但非常活跃,女神们常常在小明网上的大段发言后热情回复"呵呵",所以,小明的最爱就是和女神们约会.与此同时,也有很多基 ...

  4. 约会安排---hdu4553(线段树,麻烦的区间覆盖)

      题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=4553 算是poj3667的加强版,建立两颗线段树,一个是DS区间,另一个是NS区间.那么根据题意, ...

  5. 约会安排 HDU - 4553(线段树区间查询,区间修改,区间合并)

    题目: 寒假来了,又到了小明和女神们约会的季节.  小明虽为屌丝级码农,但非常活跃,女神们常常在小明网上的大段发言后热情回复“呵呵”,所以,小明的最爱就是和女神们约会.与此同时,也有很多基友找他开黑, ...

  6. M - 约会安排 - hdu 4553

    寒假来了,又到了小明和女神们约会的季节.  小明虽为�丝级码农,但非常活跃,女神们常常在小明网上的大段发言后热情回复“呵呵”,所以,小明的最爱就是和女神们约会.与此同时,也有很多基友找他开黑,由于数量 ...

  7. 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 ...

  8. hdu 3974 线段树 将树弄到区间上

    Assign the task Time Limit: 15000/5000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others) ...

  9. hdu 3436 线段树 一顿操作

    Queue-jumpers Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others) To ...

随机推荐

  1. RabbitMQ总结

    消息队列 三个业务场景:解耦.异步.削峰 带来问题 系统可用性降低:外部依赖越多,越容易挂掉. 系统复杂性提高:重复消费,消息丢失,消息传递的顺序性 一致性问题: 一.如何保证消息的可靠性传输(如何处 ...

  2. Python_每日习题-0008-九九乘法表

    题目: 输出9*9乘法口诀表. 程序分析:分行与分列的考虑,共9行9列,i控制行,j控制列. for i in range(1, 10): for j in range(1, i+1): print( ...

  3. 最短路DAG

    边权皆为正时,有最短路DAG. 最短路DAG代表了从原点到每个点的所有最短路. 最短路树个数=最短路DAG生成树个数.用DAG生成树计数即可.复杂度\(O(n+m)\).

  4. 【转】mysql热备

    mysql双机热备的实现 亲测可用

  5. 使用faker去构造一个User-Agent

    faker可以仿造各种各样的信息,可以使用faker去构造一个User-Agent from faker import Factory f = Factory.create() 'User-Agent ...

  6. #Leetcode# 1009. Complement of Base 10 Integer

    https://leetcode.com/problems/complement-of-base-10-integer/ Every non-negative integer N has a bina ...

  7. js原生实现div渐入渐出

    jq对渐入渐出进行封装,简单的使用连个方法就可以实现.fadeIn(),fadeOut();如果我们界面没有使用jq那么原生怎么实现呢? 我们讲解一下,这个原理.当我们要实现渐入的时候,首先是让隐藏的 ...

  8. JDBC+Servlet+JSP的学生案例增删改查

    数据库信息传输到页面实现. 先进行学生信息页面展示: 接口IStudentDao public interface IStudentDao { /** * 保存操作 * @param stu 学生对象 ...

  9. [转帖]linux下的X server:linux图形界面原理

    linux下的X server:linux图形界面原理 https://www.cnblogs.com/liangxiaofeng/p/5034912.html linux下的X server:lin ...

  10. linuxmint 搜狗输入法安装

    1.下载搜狗输入法linux安装包 2.进入安装包目录终端键入 dpkg -i [软件包名字] 3.设置语言选项中选择fcitx 4.重启电脑