C. Hotel 旅馆

内存限制:256 MiB 时间限制:1000 ms 标准输入输出
题目类型:传统 评测方式:文本比较
 

题目描述

OIER最近的旅游计划,是到长春净月潭,享受那里的湖光山色,以及明媚的阳光。作为整个旅游的策划者和负责人,贝茜选择在湖边的一家著名的旅馆住宿。这个巨大的旅馆一共有N

间客房,它们在同一层楼中顺次一字排开,在任何一个房间里,只需要拉开窗帘,就能见到波光粼粼的湖面。 所有的旅游者,都是一批批地来到旅馆的服务台,希望能订到 间连续的房间。服务台的接待工作也很简单:如果存在r满足编号为 的房间均空着,他就将这一批顾客安排到这些房间入住;如果没有满足条件的r,他会道歉说没有足够的空房间,请顾客们另找一家宾馆。如果有多个满足条件的r,服务员会选择其中最小的一个。 旅馆中的退房服务也是批量进行的。每一个退房请求由2个数字 、 描述,表示编号为 房间中的客人全部离开。退房前,请求退掉的房间中的一些,甚至是所有,可能本来就无人入住。 而你的工作,就是写一个程序,帮服务员为旅客安排房间。你的程序一共需要处理

个按输入次序到来的住店或退房的请求。第一个请求到来前,旅店中所有房间都是空闲的。

输入格式

第1行: 2个用空格隔开的整数:N、M

第2..M+1行: 第i+1描述了第i个请求,如果它是一个订房请求,则用2个数字 1、

描述,数字间用空格隔开;如果它是一个退房请求,用3 个以空格隔开的数字

、 、 描述

输出格式

第1..??行: 对于每个订房请求,输出1个独占1行的数字:如果请求能被满足 ,输出满足条件的最小的r;如果请求无法被满足,输出0

样例

样例输入

  1. 10 6
  2. 1 3
  3. 1 3
  4. 1 3
  5. 1 3
  6. 2 5 5
  7. 1 6

样例输出

  1. 1
  2. 4
  3. 7
  4. 0
  5. 5


  1. 线段树区间合并裸题 我们设这样几个数组 max_nearmax_lmax_rlazy来分别表示区间最大连续长度,从左开始的最大连续长度,从右开始的区间最大连续长度、懒度标记
     
    这样 我们的max_near就是max(max(max_near[lc],max_near[rc]),max_r[lc]+max_r[lc]) 对于max_l的维护,若左儿子的max_next等于len,那么就是左儿子的len加右儿子max_l,否则是左儿子的max_lmax_r类似。
     
    对于每次查询,如果max_near[root] < query ,那么直接输出0即可,否则的话以 左子树? 左子树右加右子树左 右子树的顺序选择递归,返回ans并从ans+query的区间范围对树进行修改。


  1. 代码:
    #include<bits/stdc++.h>
    #define re register int
    using namespace std;
    int n,m,o;
    int a,d,x,maxx;
    int max_near[500100],max_l[500100],max_r[500100],len[500100],lazy[500100],cl[500100],cr[500100];
    void pp(int k)
    {
        max_l[k]=max_l[k<<1];
        max_r[k]=max_r[k<<1|1];
        if(max_l[k]==(cr[k<<1]-cl[k<<1]+1))
            max_l[k]+=max_l[k<<1|1];
        if(max_r[k]==(cr[k<<1|1]-cl[k<<1|1]+1))
            max_r[k]+=max_r[k<<1];
        max_near[k]=max(max_r[k<<1]+max_l[k<<1|1],max(max_near[k<<1],max_near[k<<1|1]));
        
        /*
            错误搞法
        len[k]=len[k<<1]+len[k<<1|1];
        
        max_l[k]=(max_near[k<<1]==len[k<<1])?(len[k<<1]+max_l[k<<1|1]):max_l[k<<1];
        
        max_r[k]=(max_near[k<<1|1]==len[k<<1|1])?(len[k<<1|1]+max_r[k<<1]):max_r[k<<1|1];
        max_near[k]=max_r[k<<1]+max_l[k<<1|1];
        
        */
        return;
    }
    void build(int k,int l,int r)
    {
        cl[k]=l;
        cr[k]=r;
        lazy[k]=-1;
        if(l==r)
        {
            max_l[k]=max_r[k]=max_near[k]=len[k]=1;
            return;
        }
        int m=(l+r)>>1;
        build(k<<1,l,m);
        build(k<<1|1,m+1,r);
        pp(k);
    }
    void pushdown(int r,int lc,int rc)
    {
        if(lazy[r]!=-1)
        {
            lazy[lc]=lazy[rc]=lazy[r];
            if(lazy[r])
            {
                max_near[lc]=max_l[lc]=max_r[lc]=len[lc]=0;
                max_near[rc]=max_l[rc]=max_r[rc]=len[rc]=0;
            }
            else
            {
                max_near[lc]=max_l[lc]=max_r[lc]=len[lc]=cr[lc]-cl[lc]+1;
                max_near[rc]=max_l[rc]=max_r[rc]=len[rc]=cr[rc]-cl[rc]+1;
            }
            lazy[r]=-1;
        }
    }
    int que(int k,int d)
    {
        int m=(cl[k]+cr[k])>>1;
        if(cl[k]==cr[k])
            return cl[k];
        /*    
            错误,因为开端不一定在最左边!
            if(max_near[k]==d)
            return cl[k];
        */
        pushdown(k,k<<1,k<<1|1);
        if(max_near[k<<1]>=d)
            return    que(k<<1,d);
         if(max_r[k<<1]+max_l[k<<1|1]>=d)  
            return m-max_r[k<<1]+1;
        else
            return que(k<<1|1,d);
    }

    void updata(int l,int r,int root,int z)
    {
        if(l<=cl[root]&&cr[root]<=r)
        {
            lazy[root]=z;
            if(z)
                max_near[root]=max_l[root]=max_r[root]=len[root]=0;
            else
                max_near[root]=max_l[root]=max_r[root]=len[root]=cr[root]-cl[root]+1;
            return;
        }
        int m=(cr[root]+cl[root])>>1;
        pushdown(root,root<<1,root<<1|1);
        if(m>=l)
            updata(l,r,root<<1,z);
        if(m<r)
            updata(l,r,root<<1|1,z);
        pp(root);
    }
    int qian(int x)
    {
        if(cl[x<<1])
            qian(x<<1);
        if(cl[x<<1|1])
            qian(x<<1|1);
    }
    int main()
    {
        scanf("%d%d",&n,&m);
        build(1,1,n);
        for(re i=1;i<=m;i++)
        {
            scanf("%d",&a);
            if(a==1)
            {
                scanf("%d",&d);
                if(max_near[1]<d)
                {
                    printf("0\n");
                    continue;
                }
                o=que(1,d);
                printf("%d\n",o);
                updata(o,o+d-1,1,1);
            }
            else
            {
                scanf("%d%d",&x,&d);
                updata(x,x+d-1,1,0);
            }
        }
        return 0;
    }

Hotel 旅馆, 线段树查询,合并的更多相关文章

  1. 【bzoj1593】[Usaco2008 Feb]Hotel 旅馆 线段树区间合并

    题目描述 奶牛们最近的旅游计划,是到苏必利尔湖畔,享受那里的湖光山色,以及明媚的阳光.作为整个旅游的策划者和负责人,贝茜选择在湖边的一家著名的旅馆住宿.这个巨大的旅馆一共有N (1 <= N & ...

  2. Poj 3667——hotel——————【线段树区间合并】

    Hotel Time Limit: 3000MS   Memory Limit: 65536K Total Submissions: 13124   Accepted: 5664 Descriptio ...

  3. poj3667 Hotel (线段树 区间合并)

    poj3667 HotelTime Limit: 3000MS Memory Limit: 65536KTotal Submissions: 18925 Accepted: 8242Descripti ...

  4. poj 3667 Hotel (线段树的合并操作)

    Hotel The cows are journeying north to Thunder Bay in Canada to gain cultural enrichment and enjoy a ...

  5. POJ 3667 Hotel(线段树+区间合并)

    http://poj.org/problem?id=3667 题意: 有N个房间,M次操作.有两种操作(1)"1a",表示找到连续的长度为a的空房间,如果有多解,优先左边的,即表示 ...

  6. BZOJ 1593: [Usaco2008 Feb]Hotel 旅馆 [线段树]

    传送门 题意: 操作1:找长为$len$的空区间并填满,没有输出$0$ 操作2:将$[l,r]$之间的区间置空 我真是太弱了这种线段树还写了一个半小时,中间为了查错手动模拟了$30min$线段树操作, ...

  7. bzoj1593 [Usaco2008 Feb]Hotel 旅馆(线段树)

    1593: [Usaco2008 Feb]Hotel 旅馆 Time Limit: 10 Sec  Memory Limit: 64 MBSubmit: 758  Solved: 419[Submit ...

  8. POJ 3667 Hotel (线段树区间合并)

    题目链接:http://poj.org/problem?id=3667 题目大意:一共有n个房间,初始时都是空的,现在有m个操作,操作有以下两种: 1.1 d :询问是否有连续d个空的房间,若有则输出 ...

  9. (简单) POJ 3667 Hotel,线段树+区间合并。

    Description The cows are journeying north to Thunder Bay in Canada to gain cultural enrichment and e ...

随机推荐

  1. sql把一个字段中的特定字符替换成其他字符

    将'0654879'替换成'0754879' UPDATE dbo.SG_Functionality SET FunctionalityCode=REPLACE(FunctionalityCode,' ...

  2. 20204107 孙嘉临《Python程序设计》实验一报告

    课程:<python程序设计> 班级:2041 姓名:孙嘉临 学号:20204107 实验教师:王志强 实验日期:2021年4月12日 必修/选修:公选课 ##一.实验内容 1.熟悉Pyt ...

  3. Vue(11)组件化的基本使用

    前言 有时候有一组html结构的代码,并且这个上面可能还绑定了事件.然后这段代码可能有多个地方都被使用到了,如果都是拷贝来拷贝去,很多代码都是重复的,包括事件部分的代码都是重复的.那么这时候我们就可以 ...

  4. 9.5、zabbix高级操作(2)

    4.zabbix的分布式监控: 使用zabbix-proxy主动方式(被动也可),使用zabbix-agent的主动方式(被动也可): Zabbix Server <- Zabbix Proxy ...

  5. js动态添加的html绑定事件

    使用场景:网站上ul里面的li数据需要从后台数据查询出来即通过js添加数据.然后监听点击li点击事件. 添加数据代码: for(var i = 0; i < table.length; i++) ...

  6. POJ 1279 Art Gallery 半平面交 多边形的核

    题意:求多边形的核的面积 套模板即可 #include <iostream> #include <cstdio> #include <cmath> #define ...

  7. linux 开机自启动的两种方式

    方法 1 – 使用 rc.local sudo vi /etc/rc.local 在文件最后加上: sh /root/script.sh & 如果是 CentOS,我们修改的是文件 /etc/ ...

  8. 使用Hugo框架搭建博客的过程 - 前期准备

    前言 这篇教程介绍了如何搭建这样效果的博客. 所需步骤 可以从这样的角度出发: 注册域名. 使用CDN加快网站访问速度. 网站内容需要部署在服务器或对象存储平台上. 重要的是放什么内容.博客需要选择框 ...

  9. homestead

    前言 之前写过一篇文章(https://www.jianshu.com/p/5f30280a3c18),说不需要这玩意儿一样可以开发.是的,但是对于团队来说,使用统一的环境.开发工具.编码规范等,对于 ...

  10. Springboot中Rest风格请求映射如何开启并使用

    问题引入 因为前端页面只能请求两种方式:GET请求和POST请求,所以就需要后台对其进行处理 解决办法:通过springmvc中提供的HiddenHttpMethodFilter过滤器来实现 而由于我 ...