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 ...
随机推荐
- wtf_1234
好无聊啊,今天困的厉害. 不想做任何事情 wtf bitch!
- How to Install MemSQL
MemSQL runs natively on 64-bit Linux operating systems. Your system hardware must have at least 4 CP ...
- vue特殊属性 key ref slot
1.key 当使用key时,必须设置兄弟元素唯一的key,当key排列顺序变化时,兄弟元素会重新排列,而当key的值变化时,这个元素会被重新渲染. 有相同父元素的子元素必须有独特的 key.重复的 k ...
- plw的骰子
链接 [http://murphyc.fun/problem/4007] 题意 描述 duxing2016有一个神奇的骰子,投出1-6的概率为(p1,p2...p6) 现在他投n次骰子,问投出点数和大 ...
- Largest Rectangle in a Histogram HDU - 1506 (单调栈)
A histogram is a polygon composed of a sequence of rectangles aligned at a common base line. The rec ...
- 牛客练习赛38 D 题 出题人的手环 (离散化+树状数组求逆序对+前缀和)
链接:https://ac.nowcoder.com/acm/contest/358/D来源:牛客网 出题人的手环 时间限制:C/C++ 1秒,其他语言2秒 空间限制:C/C++ 524288K,其他 ...
- ElasticSearch 分组查询的几个例子
facets接口可以根据query返回统计数据,其中的 terms_stats 是分组统计,根据key的情况返回value的统计数据,类似group by的意思. "terms_stats& ...
- 每周分享之cookie详解
本章从JS方向讲解cookie的使用.(实质上后端代码也是差不多用法,无非读取和设置两块) 基本用法:document.cookie="username=pengpeng"; 修改 ...
- Java向下转型的意义
一开始学习 Java 时不重视向下转型.一直搞不清楚向下转型的意义和用途,不清楚其实就是不会,那开发的过程肯定也想不到用向下转型. 其实向上转型和向下转型都是很重要的,可能我们平时见向上转型多一点,向 ...
- Pycharm中怎么给字典中的多个键-值对同时加上单引号
今天看了个爬虫视频,崔庆才讲师的免费视频, 里面一个批量给header加引号2s完成,这波操作让我眼前一亮. 最终还是发现了骚操作的背后手速是真的快. pycharm中按ctrl+r 勾选右上角的Re ...