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 ...
随机推荐
- portscaner 多线程、多协程并发端口扫描
import socket,time,re,sys,os,threading import gevent from gevent import monkey monkey.patch_all() so ...
- 如何在Github中删除已有仓库或文件
一.删除已有仓库如果我们想要删除Github中没有用的仓库,应该如何去做呢? 进入到我们需要删除的仓库里面,找到“settings”即仓库设置: 然后,在仓库设置里拉到最底部,找到“Danger Zo ...
- ASP.NET项目开发
ASP.NET项目开发 1.C/S模式 (client 客户端 server 服务器):QQ.证券.酷狗.旺旺...需要下载响应软件: 工作原理:客户端请求--ASP.net服务器端应用(<-- ...
- Makes And The Product CodeForces - 817B (思维+构造)
B. Makes And The Product time limit per test 2 seconds memory limit per test 256 megabytes input sta ...
- Day11 Python基础之装饰器(高级函数)(九)
在python中,装饰器.生成器和迭代器是特别重要的高级函数 https://www.cnblogs.com/yuanchenqi/articles/5830025.html 装饰器 1.如果说装 ...
- hibernate 的sum(filed)引发的NullPointException错误解决过程
背景: 在用hql语句进行sum查询时遭遇NPE问题: StringBuilder builder = new StringBuilder("select SUM(actualWorking ...
- jmeter高并发设计方案(转)
高并发设计方案二(秒杀架构) 优化方向: (1)将请求尽量拦截在系统上游(不要让锁冲突落到数据库上去).传统秒杀系统之所以挂,请求都压倒了后端数据层,数据读写锁冲突严重,并发高响应慢,几乎所有请求都超 ...
- java从request中获取GET和POST请求参数
URL和参数列表 一 获取请求方式 request.getMethod(); get和post都可用, 二 获取请求类型 request.getContentType(); get和post都可用,示 ...
- MyBaits全局配置文件的各项标签1
■dtd约束 <!DOCTYPE configuration PUBLIC "-//mybatis.org//DTD Config 3.0//EN" ...
- MongoDB操作(1)—MongoDB java驱动核心层次结构及操作流程
MongoDB之java驱动学习 预备: 本地运行MongoDB采用默认端口20717: 安装MongoDB驱动: 以下关键步骤. 核心层次结构或步骤: 创建连接池:MongoClient实例. 对于 ...