传送门

题意简述:现在给你一个长度为mmm的环,有nnn条互不包含的线段,问如果强制选第iii条线段至少需要用几条线段覆盖这个环,注意用来的覆盖的线段应该相交,即[1,3],[4,5][1,3],[4,5][1,3],[4,5]不合法[1,4],[4,5][1,4],[4,5][1,4],[4,5]合法。


思路:把坐标先离散化,然后破环为链,接着用线段树维护每个点向左走一步最多走到哪个点,然后就可以用ststst表维护每个点向左走2k2^k2k步最多走到哪个点,最后对于每条线段倍增求答案即可。

代码:

#include<bits/stdc++.h>
#define fi first
#define se second
#define ri register int
using namespace std;
const int rlen=1<<18|1;
inline char gc(){
    static char buf[rlen],*ib,*ob;
    (ib==ob)&&(ob=(ib=buf)+fread(buf,1,rlen,stdin));
    return ib==ob?-1:*ib++;
}
inline int read(){
    int ans=0;
    char ch=gc();
    while(!isdigit(ch))ch=gc();
    while(isdigit(ch))ans=((ans<<2)+ans<<1)+(ch^48),ch=gc();
    return ans;
}
typedef pair<int,int> pii;
const int N=8e5+5;
int n,m,val[N],sig=0,st[N][20],vl[2][N],vr[2][N];
pii a[N];
namespace sgt{
    #define lc (p<<1)
    #define rc (p<<1|1)
    #define mid (l+r>>1)
    int mx[N<<2];
    inline void pushnow(int p,int v){mx[p]=max(mx[p],v);}
    inline void pushdown(int p){pushnow(lc,mx[p]),pushnow(rc,mx[p]);}
    inline void update(int p,int l,int r,int ql,int qr,int v){
        if(ql<=l&&r<=qr)return pushnow(p,v);
        pushdown(p);
        if(qr<=mid)update(lc,l,mid,ql,qr,v);
        else if(ql>mid)update(rc,mid+1,r,ql,qr,v);
        else update(lc,l,mid,ql,mid,v),update(rc,mid+1,r,mid+1,r,v);
    }
    inline void query(int p,int l,int r){
        if(l==r){st[l][0]=mx[p];return;}
        pushdown(p);
        query(lc,l,mid),query(rc,mid+1,r);
    }
    #undef lc
    #undef rc
    #undef mid
}
inline int find(const int&x){return lower_bound(val+1,val+sig+1,x)-val;}
inline int query(int s,int t){
    int ret=0;
    for(ri i=19;~i;--i){
        if(!st[s][i]||st[s][i]>=t)continue;
        s=st[s][i];
        ret|=1<<i;
    }
    return ret+1;
}
int main(){
    n=read(),m=read();
    val[++sig]=1,val[++sig]=m,val[++sig]=m+1,val[++sig]=m<<1;
    for(ri i=1;i<=n;++i)val[++sig]=a[i].fi=read(),val[++sig]=a[i].se=read(),val[++sig]=a[i].fi+m,val[++sig]=a[i].se+m;
    sort(val+1,val+sig+1),sig=unique(val+1,val+sig+1)-val-1;
    for(ri i=1;i<=n;++i)vl[0][i]=find(a[i].fi),vl[1][i]=find(a[i].fi+m),vr[0][i]=find(a[i].se),vr[1][i]=find(a[i].se+m);
    for(ri i=1;i<=n;++i){
        if(a[i].fi<=a[i].se){
            sgt::update(1,1,sig,vl[0][i],vr[0][i],vr[0][i]);
            sgt::update(1,1,sig,vl[1][i],vr[1][i],vr[1][i]);
        }
        else{
            sgt::update(1,1,sig,1,vr[0][i],vr[0][i]);
            sgt::update(1,1,sig,vl[0][i],vr[1][i],vr[1][i]);
            sgt::update(1,1,sig,vl[1][i],sig,sig);
        }
    }
    sgt::query(1,1,sig);
    for(ri j=1;j<20;++j)for(ri i=1;i<=sig;++i)st[i][j]=st[st[i][j-1]][j-1];
    for(ri i=1;i<=n;++i)cout<<1+query(a[i].se<a[i].fi?vr[1][i]:vr[0][i],vl[1][i])<<' ';
    return 0;
}

2019.03.26 bzoj4444: [Scoi2015]国旗计划(线段树+倍增)的更多相关文章

  1. BZOJ4444 SCOI2015国旗计划(贪心+倍增)

    链上问题是一个经典的贪心.于是考虑破环成链,将链倍长.求出每个线段右边能作为后继的最远线段,然后倍增即可. #include<iostream> #include<cstdio> ...

  2. 2019.03.26 bzoj4448: [Scoi2015]情报传递(归并排序+树链剖分)

    传送门 题意简述: 给一棵nnn个点的树,树上每个点表示一个情报员,一共有mmm天,每天会派发以下两种任务中的一个任务: 1.搜集情报:指派T号情报员搜集情报 2.传递情报:将一条情报从X号情报员传递 ...

  3. 2019.03.26 bzoj4447: [Scoi2015]小凸解密码(线段树)

    传送门 题意简述:咕咕咕 思路:考虑预处理出bbb数组,然后每次改动aaa都只会对第iii和i+1i+1i+1这两个位置产生影响,于是可以用线段树来维护bbb数组. 现在求答案的方法是断环为链,倍增整 ...

  4. 2019.03.09 codeforces833B. The Bakery(线段树优化dp)

    传送门 线段树优化dpdpdp入门题. 要求把nnn个数分成kkk段,每段价值为里面不相同的数的个数,求所有段的价值之和最大值.n≤35000,k≤50n\le35000,k\le50n≤35000, ...

  5. [BZOJ4444][SCOI2015]国旗计划(倍增)

    链上是经典贪心问题,将线段全按左端点排序后把点全撒在线段右端点上.这里放到环上,倍长即可. 题目保证不存在区间包含情况,于是有一种暴力做法,先将战士的管辖区间按左端点从小到大排序,对于询问x,从x战士 ...

  6. BZOJ4444 : [Scoi2015]国旗计划

    首先将坐标离散化,因为区间互不包含,可以理解为对于每个起点输出最少需要多少个战士. 将环倍长,破环成链,设$f[i]$表示区间左端点不超过$i$时右端点的最大值,可以通过$O(n)$递推求出. 那么如 ...

  7. 2019.03.26 bzoj4446: [Scoi2015]小凸玩密室(树形dp)

    传送门 题意简述: 给一棵完全二叉树,有点权aia_iai​和边权,每个点有一盏灯,现在要按一定要求点亮: 任意时刻点亮的灯泡必须连通 点亮一个灯泡后必须先点亮其子树 费用计算如下:点第一盏灯不要花费 ...

  8. [BZOJ4444][SCOI2015]国旗计划-[ST表]

    Description 传送门 Solution 说真的这道题在场上没做出来的我必定是脑子有洞.. 我们用st表记录以某个位置开始,派了1<<j个战士能到达的最远位置. 由于边境线是一圈, ...

  9. 【BZOJ4444】[Scoi2015]国旗计划 双指针+倍增

    [BZOJ4444][Scoi2015]国旗计划 Description A国正在开展一项伟大的计划——国旗计划.这项计划的内容是边防战士手举国旗环绕边境线奔袭一圈.这项计划需要多名边防战士以接力的形 ...

随机推荐

  1. Mongodb到mysql数据库的数据迁移(Java,Windows)

    运行环境为windows 测试过260万的数据表,迁移大概要10分钟左右,当然肯定和网络,字段大小什么的有关系. 遇到的坑和注意点都用紫色标记了(对,就是我大乃团的高冷紫--Nogizaka 46) ...

  2. Django启动报错笔记

    NO.1: You have 15 unapplied migration(s). Your project may not work properly until you apply the mig ...

  3. 深入理解C++11【5】

    [深入理解C++11[5]] 1.原子操作与C++11原子类型 C++98 中的原子操作.mutex.pthread: #include<pthread.h> #include <i ...

  4. 复杂JSON对象的查询与合并

    一个表里存放了全国各地地区.省.市.县区的数据,为了提高加载速度我保存成了本地的JSON文件 结构大致如下: [{ "text": "中华人民共和国", &qu ...

  5. 分布式系统里session同步

    https://blog.csdn.net/xyw591238/article/details/51644315

  6. Java基础(命令行操作、注释及API、)

    一.常用的dos命令. dir:列出当前目录下的文件及文件夹 md:创建目录 rd:删除目录 cd:进入到指定目录 cd..:退出到上一级目录 cd\:退出到根目录 del:删除文件 exit:退出d ...

  7. redis设置密码

    1.初始化Redis密码: 在redis.conf配置文件中有个参数: requirepass  这个就是配置redis访问密码的参数: 比如 requirepass test123: (Ps:需重启 ...

  8. 使用Fiddle对夜神模拟器进行抓包的设置

    注意: 设置完后, 不开启 Fiddle 的话,模拟器就不能上网了.  可以通过再把网络配置 改回去 就可以恢复网络正常访问了 一.配置Fiddle参数设置 1.Tools->Options 2 ...

  9. 10.spring-boot基于角色的权限管理页面实现

    10.spring-boot基于角色的权限管理页面实现

  10. 关于js中操作数组的一些方法

    网上找的通篇看了一遍讲的很透收藏了!  转自(https://www.cnblogs.com/blogs-8888/p/6518683.html) 1.锁定数组的长度(让数组的长度变成只读). 1 2 ...