Description

  

   题目链接

  

  

  

Solution

磕了3个半小时没做出来的题,就是全场崩.

  

   首先对于一个人的答案是很好求的,显然是选择左端点在此人区间中,右端点最远(最靠右)的人作为下一个接棒人.因此用线段树维护一下就可以了,注意判断跨环边界的情况(n->1).

  

   时间复杂度$ \mathcal O(n^2 \log n) $.

  

   接着我再想,如果按左端点从大到小从右往左注意处理,每个人其实就是选择那些左端点处于自己区间中的人作为后继,选择它们的答案最小值即可.然而终止点也是不断移动的,所以每个人的答案在之后的人看是动态的.考虑很难修改,就猜性质,猜了个性质,用2h实现程序暴力和数据生成器,然后一组数据见祖宗.

  

   TMD

  

   稍微换一下思路,与其想办法维护接力方案,不如直接考虑计算每个人,并优化这个过程.

  

   可以发现,每个人选择哪一个人作为下一棒是唯一确定的(左端点在区间内的人中,右端点最远的那个人). 且每传一次棒,贡献的距离也是唯一确定的(当前人的右端点与下一棒的右端点的距离).

  

   确定下一棒可以用线段树直接模拟.

  

   对于每个人\(i\),我们相当于要知道从他开始至少传多少棒之后,总距离贡献超过了\(m-len_i\). 其中\(len_i\)表示这个人的区间长度减一.

  

   那么倍增出传\(2^k\)步后是谁,以及总距离贡献是多少.

  

   对于每个人直接从大到小枚举\(k\)逐步逼近目标步数即可.

  

   总时间复杂度是\(\mathcal O (n \log n)\)

  

  

  

Code

  

#include <cstdio>
#include <algorithm>
#define mp make_pair
using namespace std;
typedef pair<int,int> pii;
typedef long long ll;
const int N=200005;
const int INF=1e9;
int n,m;
int diz[N*2],dcnt,who[N*2];
int go[N][19];
ll d[N][19];
struct Man{
int l,r,id;
int get(){
if(l<r) return r-l;
return r+(dcnt-l);
}
}p[N];
void readData(){
scanf("%d%d",&n,&m);
for(int i=1;i<=n;i++){
scanf("%d%d",&p[i].l,&p[i].r);
p[i].id=i;
}
}
void Diz(){
for(int i=1;i<=n;i++){
diz[++dcnt]=p[i].l;
diz[++dcnt]=p[i].r;
}
sort(diz+1,diz+1+dcnt);
dcnt=unique(diz+1,diz+1+dcnt)-diz-1;
for(int i=1;i<=n;i++){
p[i].l=lower_bound(diz+1,diz+1+dcnt,p[i].l)-diz;
p[i].r=lower_bound(diz+1,diz+1+dcnt,p[i].r)-diz;
}
}
bool cmpMan(const Man &a,const Man &b){
return a.l<b.l;
}
pii max(pii x,pii y){
return x.first>y.first?x:y;
}
namespace SEG{/*{{{*/
const int S=N*4;
int rt,sz;
int ch[S][2];
pii info[S];
inline void pushup(int u){
info[u]=max(info[ch[u][0]],info[ch[u][1]]);
}
void build(int &u,int l,int r){
u=++sz;
if(l==r){
info[u]=mp(-INF,-INF);
return;
}
int mid=(l+r)>>1;
build(ch[u][0],l,mid);
build(ch[u][1],mid+1,r);
pushup(u);
}
void modify(int u,int l,int r,int pos,pii val){
if(l==r){
info[u]=val;
return;
}
int mid=(l+r)>>1;
if(pos<=mid)
modify(ch[u][0],l,mid,pos,val);
else
modify(ch[u][1],mid+1,r,pos,val);
pushup(u);
}
pii query(int u,int l,int r,int L,int R){
if(L<=l&&r<=R) return info[u];
int mid=(l+r)>>1;
if(R<=mid) return query(ch[u][0],l,mid,L,R);
else if(mid<L) return query(ch[u][1],mid+1,r,L,R);
else
return max(query(ch[u][0],l,mid,L,mid),query(ch[u][1],mid+1,r,mid+1,R));
}
}/*}}}*/
void calc(){
SEG::build(SEG::rt,1,dcnt);
for(int i=1;i<=n;i++)
SEG::modify(SEG::rt,1,dcnt,p[i].l,mp(p[i].l>p[i].r?p[i].r+dcnt:p[i].r,i));
for(int i=1;i<=n;i++){
int x;
pii get;
if(p[i].l<p[i].r)
get=SEG::query(SEG::rt,1,dcnt,p[i].l+1,p[i].r);
else{
get=mp(-INF,-INF);
if(p[i].l<dcnt)
get=SEG::query(SEG::rt,1,dcnt,p[i].l+1,dcnt);
pii tmp=SEG::query(SEG::rt,1,dcnt,1,p[i].r);
tmp.first+=dcnt;
get=max(get,tmp);
}
go[i][0]=get.second;
d[i][0]=get.first-(p[i].l>p[i].r?p[i].r+dcnt:p[i].r);
}
for(int j=1;j<=18;j++)
for(int u=1;u<=n;u++){
go[u][j]=go[go[u][j-1]][j-1];
d[u][j]=d[u][j-1]+d[go[u][j-1]][j-1];
}
}
void solve(){
for(int i=1;i<=n;i++){
int ans=1;
int u=i,last=dcnt-p[i].get();
for(int j=18;j>=0;j--)
if(d[u][j]<last){
last-=d[u][j];
ans+=(1<<j);
u=go[u][j];
}
printf("%d ",ans+1);
}
puts("");
}
int main(){
readData();
Diz();
calc();
solve();
return 0;
}

【BZOJ4444】国旗计划的更多相关文章

  1. [bzoj4444] 国旗计划 双指针+倍增

    Description A国正在开展一项伟大的计划--国旗计划.这项计划的内容是边防战士手举国旗环绕边境线奔袭一圈.这项计划需要多名边防战士以接力的形式共同完成,为此,国土安全局已经挑选了N名优秀的边 ...

  2. bzoj4444 国旗计划

    题目链接 倍增,预处理出每个点往后$2^i$个应该选哪个人 我用的treap就是快 #include<algorithm> #include<iostream> #includ ...

  3. luogu4155/bzoj4444 国旗计划 (倍增)

    成环,把每个区间变成两个然后展开成链 一个人的下一个人肯定是在彼此相交的基础上,右端点越大越好 于是就把它连到相交的.右端点最大的点上,连成一棵树 于是每次只要从某个节点开始,一直在树上跳到覆盖了一个 ...

  4. 【bzoj4444 scoi2015】国旗计划

    题目描述 A 国正在开展一项伟大的计划 —— 国旗计划.这项计划的内容是边防战士手举国旗环绕边境线奔袭一圈.这项计划需要多名边防战士以接力的形式共同完成,为此,国土安全局已经挑选了 NN 名优秀的边防 ...

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

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

  6. [BZOJ4444] [Luogu 4155] [LOJ 2007] [SCOI2015]国旗计划(倍增)

    [BZOJ4444] [Luogu 4155] [LOJ 2007] [SCOI2015]国旗计划(倍增) 题面 题面较长,略 分析 首先套路的断环为链.对于从l到r的环上区间,若l<=r,我们 ...

  7. 【bzoj4444】[Scoi2015]国旗计划 倍增

    题目描述 给出一个圈和若干段,问:对于所有的 $i$ ,选择第 $i$ 段的情况下,最少需要选择多少段(包括第 $i$ 段)能够覆盖整个圈? 输入 第1行,包含2个正整数N,M,分别表示边防战士数量和 ...

  8. 【BZOJ4444】国旗计划 - 决策单调性

    Description A国正在开展一项伟大的计划——国旗计划.这项计划的内容是边防战士手举国旗环绕边境线奔袭一圈.这项计划需要多名边防战士以接力的形式共同完成,为此,国土安全局已经挑选了N名优秀的边 ...

  9. [bzoj4444] [loj#2007] [洛谷P4155] [Scoi2015] 国旗计划

    Description \(A\) 国正在开展一项伟大的计划--国旗计划.这项计划的内容是边防战士手举国旗环绕边境线奔袭一圈.这项计划需要多名边防战士以接力的形式共同完成,为此,国土安全局已经挑选了 ...

  10. bzoj 4444: [Scoi2015]国旗计划

    Description A国正在开展一项伟大的计划--国旗计划.这项计划的内容是边防战士手举国旗环绕边境线奔袭一圈.这 项计划需要多名边防战士以接力的形式共同完成,为此,国土安全局已经挑选了N名优秀的 ...

随机推荐

  1. ASP.NET Core 3.0 实战:构建多版本 API 接口

    第一次在博客写分享,请多多捧场,如有歧义请多多包含! 因为业务需求发展需要,所以API接口的变更升级是必不可少的事情,而原有的接口是不可能马上停止使用的.例如:Login接口为例,1.0版本之返回用户 ...

  2. excel实用技巧——vlookup函数

    1.VLOOKUP函数的套路 VLOOKUP(要找谁,在哪儿找,返回第几列的内容,精确找还是近似找) 最后一个参数: 如果为0或FASLE,用精确匹配方式,而且支持无序查找: 如果为TRUE或被省略, ...

  3. 20155217《网络对抗》Exp06 信息搜集与漏洞扫描

    20155217<网络对抗>Exp06 信息搜集与漏洞扫描 实践内容 各种搜索技巧的应用 DNS IP注册信息的查询 基本的扫描技术:主机发现.端口扫描.OS及服务版本探测.具体服务的查点 ...

  4. 20155325 Exp4 恶意代码分析

    系统运行监控 (1)使用如计划任务,每隔一分钟记录自己的电脑有哪些程序在联网,连接的外部IP是哪里.运行一段时间并分析该文件,综述一下分析结果.目标就是找出所有连网的程序,连了哪里,大约干了什么(不抓 ...

  5. Hadoop开发第2期---虚拟机中搭建Linux

    注:关于如何将hadoop源码导入Eclipse详见http://pan.baidu.com/s/1hq8ArUs 一.Hadoop配置软件(我的电脑是Windows7旗舰--64bit) 1. VM ...

  6. Caffe源码中common文件分析

    Caffe源码(caffe version:09868ac , date: 2015.08.15)中的一些重要头文件如caffe.hpp.blob.hpp等或者外部调用Caffe库使用时,一般都会in ...

  7. CS190.1x Scalable Machine Learning

    这门课是CS100.1x的后续课,看课程名字就知道这门课主要讲机器学习.难度也会比上一门课大一点.如果你对这门课感兴趣,可以看看我这篇博客,如果对PySpark感兴趣,可以看我分析作业的博客. Cou ...

  8. R绘图 第十篇:绘制文本、注释和主题(ggplot2)

    使用ggplot2包绘制时,为了更直观地向用户显示报表的内容和外观,需要使用geom_text()函数添加文本说明,使用annotate()添加注释,并通过theme()来调整非数据的外观. 一,文本 ...

  9. SSIS 组件属性整理

    整理SSIS 组件的属性解释及其用法 一,ExecValueVariable属性 有些Task组件执行完成之后,会产生输出结果,称作Execution Value,例如,Execute SQL Tas ...

  10. startActivity时报错Calling startActivity() from outside of an Activity context requires the FLAG_ACTIVI

    原代码如下: Intent intent = new Intent(); intent.setClass(mContext, PhotoView.class); Bundle bundle = new ...