首先将区间按长度排序后离散化端点(这里的“长度”指的是离散化之前区间的实际长度)

然后模拟一个队列,区间按排好的顺序依次进入,直到某个点被覆盖了M次。之后依次出队,直到所有点都被覆盖小于M次

修改和询问覆盖次数可以用线段树实现

 //C++11 code

 #include <cstdio>
 #include <cstring>
 #include <algorithm>

 ;
 const int inf=0x7f7f7f7f;

 struct Range
 {
     int left,right;
     int len;
     void assign(int l,int r) { left=l; right=r; len=r-l; }
 };

 struct SegTree
 {
     struct Node
     {
         ; //max-val
         ;
         int total() { return val+tag; }
     };
     Node node[maxN<<];
     int size;
     int _val;

     void update(int cur,int right)
     {
         node[cur].val = std::max(node[cur+].total(),node[right].total());
     }
     void add(int L,int R,int val)
     {
         _val=val;
         __add(,L,R+,,size);
     }
     void __add(int cur,int rL,int rR,int nL,int nR)
     {
         if(rL<=nL && rR>=nR)
         {
             node[cur].tag+=_val;
             return;
         }
         ;
         );
         ,rL,rR,nL,mid);
         if(rR>mid) __add(right,rL,rR,mid,nR);
         update(cur,right);
     }
     ].total(); }
 };

 Range rg[maxN];
 SegTree segt;

 int N,M;
 ];
 int valNum;

 void input()
 {
     scanf("%d%d",&N,&M);
     int tl,tr;
     ;i<N;i++)
     {
         scanf("%d%d",&tl,&tr);
         buf[i<<]=tl;
         buf[(i<<)+]=tr;
         rg[i].assign(tl,tr);
     }
 }

 void discretize()
 {
     std::sort(buf,buf+(N<<));
     valNum=std::unique(buf,buf+(N<<))-buf;
     ;i<N;i++)
     {
         rg[i].left=std::lower_bound(buf,buf+valNum,rg[i].left)-buf;
         rg[i].right=std::lower_bound(buf,buf+valNum,rg[i].right)-buf;
     }
 }

 int solve()
 {
     int res=inf;
     auto cmpIdx=[](const Range& A,const Range& B)->bool { return A.len<B.len; };
     std::sort(rg,rg+N,cmpIdx);
     discretize();
     segt.size=valNum;
     ,tail=-;
     )
     {
         while((++head)<N && segt.askAll()<M)
             segt.add(rg[head].left,rg[head].right,);
         if(segt.askAll()<M) break;
         else --head;
         while(segt.askAll()==M)
         {
             ++tail;
             res=std::min(res,rg[head].len-rg[tail].len);
             segt.add(rg[tail].left,rg[tail].right,-);
         }
     }
     :res;
 }

 int main()
 {
     input();
     printf("%d\n",solve());
     ;
 }

UOJ222 NOI2016 区间 线段树+FIFO队列的更多相关文章

  1. BZOJ.4653.[NOI2016]区间(线段树)

    BZOJ4653 UOJ222 考虑二分.那么我们可以按区间长度从小到大枚举每个区间,对每个区间可以得到一个可用区间长度范围. 我们要求是否存在一个点被这些区间覆盖至少\(m\)次.这可以用线段树区间 ...

  2. [NOI2016]区间 线段树

    [NOI2016]区间 LG传送门 考虑到这题的代价是最长边减最短边,可以先把边按长度排个序,双指针维护一个尺取的过程,如果存在包含某个点的区间数\(\ge m\),就更新答案并把左指针右移,这样做的 ...

  3. Luogu P1712 [NOI2016]区间(线段树)

    P1712 [NOI2016]区间 题意 题目描述 在数轴上有 \(N\) 个闭区间 \([l_1,r_1],[l_2,r_2],...,[l_n,r_n]\) .现在要从中选出 \(M\) 个区间, ...

  4. BZOJ4653 [NOI2016]区间 [线段树,离散化]

    题目传送门 区间 Description 在数轴上有 n个闭区间 [l1,r1],[l2,r2],...,[ln,rn].现在要从中选出 m 个区间,使得这 m个区间共同包含至少一个位置.换句话说,就 ...

  5. BZOJ4653: [Noi2016]区间(线段树 双指针)

    题意 题目链接 Sol 按照dls的说法,一般这一类的题有两种思路,一种是枚举一个点\(M\),然后check它能否成为答案.但是对于此题来说好像不好搞 另一种思路是枚举最小的区间长度是多少,这样我们 ...

  6. 洛谷$P1712\ [NOI2016]$区间 线段树

    正解:线段树 解题报告: 传送门$QwQ$ $umm$很久以前做的了来补个题解$QwQ$ 考虑给每个区间按权值($r-l$从大往小排序,依次加入,然后考虑如果有一个位置被覆盖次数等于$m$了就可以把权 ...

  7. BZOJ4653:[NOI2016]区间(线段树)

    Description 在数轴上有 n个闭区间 [l1,r1],[l2,r2],...,[ln,rn].现在要从中选出 m 个区间,使得这 m个区间共同包含至少一个位置.换句话说,就是使得存在一个 x ...

  8. 【BZOJ-2892&1171】强袭作战&大sz的游戏 权值线段树+单调队列+标记永久化+DP

    2892: 强袭作战 Time Limit: 50 Sec  Memory Limit: 512 MBSubmit: 45  Solved: 30[Submit][Status][Discuss] D ...

  9. hdu 1540 Tunnel Warfare (区间线段树(模板))

    http://acm.hdu.edu.cn/showproblem.php?pid=1540 Tunnel Warfare Time Limit: 4000/2000 MS (Java/Others) ...

随机推荐

  1. 数据结构(分块):[HZOI 2015]easy seq

    [题目描述] 给定一个序列,下标从0开始,分别为a0,a1,a2...an−1,有m个询问,每次给出l和r,求满足ai=aj且l<=i<=j<=r时j−i的最大值 本题强制在线,l和 ...

  2. codeforces 421d bug in code

    题目链接:http://codeforces.com/problemset/problem/421/D 题目大意:每个人说出自己认为的背锅的两个人,最后大BOSS找两个人来背锅,要求至少符合p个人的想 ...

  3. 突破LVS瓶颈,LVS Cluster部署(OSPF + LVS) - lxcong的运维技术 - 开源中国社区

    突破LVS瓶颈,LVS Cluster部署(OSPF + LVS) - lxcong的运维技术 - 开源中国社区 突破LVS瓶颈,LVS Cluster部署(OSPF + LVS)

  4. Eclipse下Tomcat常用设置

    Eclipse下Tomcat常用设置 1,Eclipse建立Tomcat服务 1.1 新建Server 首先这里是指,jee版的Eclipse.Eclipse是没有像MyEclipse那样集成Tomc ...

  5. 【转】HTML5的语音输入 渐进使用HTML5语言识别, so easy!

    转自: 本文地址:http://www.zhangxinxu.com/wordpress/?p=2408 一.本不想写此文 HTML5语音识别(现在一般用在搜索上),目前相关介绍还是挺多的.为何呢?因 ...

  6. [转]Android中dp,px,sp概念梳理以及如何做到屏幕适配

    http://blog.csdn.net/jiangwei0910410003/article/details/40509571 今天又开始我的App开发,因为之前一直做的是SDK,所以涉及到界面UI ...

  7. 使用 maven:archetype 创建JSF2 + EJB3.1 + JPA2项目骨架并在JBoss WildFly 8.1上部署

    运行下面命令创建项目骨架: mvn archetype:generate -DarchetypeGroupId=org.jboss.spec.archetypes -DarchetypeArtifac ...

  8. delphi TFontDialog

      设置前先获得Memo的字体属性并设置给FontDialog 然后再设置MEMO的字体属性   //设置Memo的字体属性 procedure TForm1.mni_FontClick(Sender ...

  9. APP安全环节缺失,手游运营商怎样应对APP破解困境

    2013年手游行业的规模与收入均实现了大幅增长,发展势头强劲.然而,在手游快速发展的同一时候,因为监管.审核等方面存在着漏洞,手机游戏软件被破解后注入恶意代码.盗取用户財产.窃取用户设备信息的现象屡见 ...

  10. Android-自己定义图像资源的使用(1)

    Android-自己定义图像资源的使用 2014年4月28日 周一 天气晴朗 心情平静 本篇博文给大家介绍一下,在Android开发中经经常使用到的一些图像资源,具体内容麻烦请各位认真查看官网,下面附 ...