公元2222年,l国发生了一场战争。
  小Y负责领导工人运输物资。
  其中有m种物资的运输方案,每种运输方案形如li,ri。表示存在一种货物从li运到ri。
  这里有n个城市,第i个城市与第i+1个城市相连(这里1号城市和n号城市并不相连),并且从i号城市走到i+1号或者从i+1号走到i号需要耗费1点时间。
  由于高科技的存在,小Y想到了一种节省时间的好方案。在X号城市与Y号城市之间设立传送站,只要这么做,在X号城市走到Y号城市不需要耗费时间,同样的,从Y号城市走到X号城市也不需要耗费时间。
  但是为了防止混乱,只能设立这么一条传送站。
  现在这些运输方案同时进行,小Y想让最后到达目的地的运输方案时间最短。

  在样例中,存在两条运输方案,分别是1号城市到3号与2号到4号,那么我们在2号城市与3号城市建立传送站,这样运输方案时间最长的只需要1点时间就可以了。
 Input
  第一行两个整数n,m(1<=n,m<=500000)。
  接下来m行,每行两个整数li,ri(1<=li,ri<=n)。(若li=ri,则不需要耗费任何时间)
 Output
  一个数表示答案。

  依旧是看了题解。。二分答案mid,假设传送站修在X--Y,那么对于每个R-L>mid的方案L-->R,就只能走L-->X-->Y-->R。

  如果L>X,那么abs(R-Y)<=mid-(L-x),即 R-(mid-(L-X)) <=Y<= R+(mid-(L-X))

  可以发现。。只考虑可行性的话,X是可以丢掉的。。。L<=X同理

  那么只要枚举X,记录L<=X的所有方案的区间交,还有L>X的所有方案的区间交。。只要两个区间交非空就合法了。

 #include<cstdio>
#include<iostream>
#include<cstring>
#include<algorithm>
#include<queue>
#define ll long long
#define ui unsigned int
#define ull unsigned long long
const int maxn=,inf=;
struct zs{int l,r;}a[maxn];
struct zs1{int l,r,l1,r1,l2,r2;}b[maxn];
int l1[maxn],r1[maxn];
int i,j,k,n,m,mx;
ll ans; int ra,fh;char rx;
inline int read(){
rx=getchar(),ra=,fh=;
while((rx<''||rx>'')&&rx!='-')rx=getchar();
if(rx=='-')fh=-,rx=getchar();
while(rx>=''&&rx<='')ra*=,ra+=rx-,rx=getchar();return ra*fh;
}
inline int max(int a,int b){return a>b?a:b;}
inline int min(int a,int b){return a<b?a:b;}
inline void maxs(int &a,int b){if(b>a)a=b;}
inline void mins(int &a,int b){if(b<a)a=b;}
inline bool check(int mid){
int cnt=,l2,r2;register int i;
for(i=;i<=n;i++)if(a[i].r-a[i].l>mid)
cnt++,
b[cnt].l=a[i].l,b[cnt].r=a[i].r,
b[cnt].l1= a[i].l+a[i].r-mid,b[cnt].r1=-a[i].l+a[i].r+mid,
b[cnt].l2=-a[i].l+a[i].r-mid,b[cnt].r2= a[i].l+a[i].r+mid;
l1[mx+]=l2=-inf,r1[mx+]=r2=inf;int top=cnt;
for(i=mx;i;i--){
l1[i]=l1[i+],r1[i]=r1[i+];
while(top&&b[top].l>=i)
maxs(l1[i],b[top].l1),mins(r1[i],b[top].r1),top--;
}top=;
for(i=;i<=mx;i++){
while(top<=cnt&&b[top].l<=i)
maxs(l2,b[top].l2),mins(r2,b[top].r2),top++;
if(l1[i]-i<=r1[i]+i&&l2+i<=r2-i)
if(!(r1[i]+i<l2+i||(l1[i]-i>r2-i)))
return /*printf("X:%d %d--%d %d--%d\n",i,l1[i]-i,r1[i]+i,l2+(i),r2-(i)),*/;
}return ;
} bool operator <(zs a,zs b){return a.l<b.l;}
int main(){
mx=read(),n=read();int l=,r=,mid;
for(i=;i<=n;i++){
a[i].l=read(),a[i].r=read();
if(a[i].l>a[i].r)std::swap(a[i].l,a[i].r);
r=max(r,a[i].r-a[i].l);
}
std::sort(a+,a++n);
while(l<r)if(check(mid=l+r>>))r=mid;else l=mid+;
printf("%d\n",l);
}

[51nod1671]货物运输的更多相关文章

  1. 【LCA&倍增】货物运输 @upcexam5909

    时间限制: 1 Sec 内存限制: 128 MB 题目描述 在一片苍茫的大海上,有n座岛屿,岛屿与岛屿之间由桥梁连接,所有的岛屿刚好被桥梁连接成一个树形结构,即共n-1架桥梁,且从任何一座岛屿出发都能 ...

  2. HDU 5699 货物运输 二分

    货物运输 题目连接: http://acm.hdu.edu.cn/showproblem.php?pid=5699 Description 公元2222年,l国发生了一场战争. 小Y负责领导工人运输物 ...

  3. Django自学计划之集装箱货物运输物流仓储一站式ERP系统

    业余开始学习时间:2018年1月 业余学习时间段:每天下班晚饭后时间+无事的星期六和星期天+上班时的空闲时间 自学目标: 1.我们要用管理的思维来写我们的系统! 2.我们要用我们的ERP系统帮助中小集 ...

  4. 51nod1671【货物运输】

    开始天真的我以为这道题和运输计划是一样的套路.于是写了一发,debug后发现过了第一个点,十分开心的交了一发,结果只过了第一个点.后来发现这个并不是一样的,因为修建黑洞之后路径法变了,而运输计划没有( ...

  5. 货物运输 51Nod - 1671

    公元2222年,l国发生了一场战争. 小Y负责领导工人运输物资. 其中有m种物资的运输方案,每种运输方案形如li,ri.表示存在一种货物从li运到ri. 这里有n个城市,第i个城市与第i+1个城市相连 ...

  6. HDU 5699 货物运输 二分判定

    转自:http://blog.csdn.net/jtjy568805874/article/details/51480479 #include <cstdio> #include < ...

  7. bzoj1003 物流运输

    Description 物流公司要把一批货物从码头A运到码头B.由于货物量比较大,需要n天才能运完.货物运输过程中一般要转停好几个码头.物流公司通常会设计一条固定的运输路线,以便对整个运输过程实施严格 ...

  8. 【BZOJ1003】【ZJOI2006】物流运输

    1003: [ZJOI2006]物流运输trans Time Limit: 10 Sec  Memory Limit: 162 MBSubmit: 2556  Solved: 1008[Submit] ...

  9. BZOJ 1003 物流运输 题解 【SPFA+DP】

    BZOJ 1003 物流运输 题解 Description 物流公司要把一批货物从码头A运到码头B.由于货物量比较大,需要n天才能运完.货物运输过程中一般要转停好几个码头.物流公司通常会设计一条固定的 ...

随机推荐

  1. iOS开发富文本制作 图片和文字/NSMutableParagraphStyle/NSMutableAttributedString

    /NSMutableParagraphStyle/NSMutableAttributedString 组合使 NSString * titlestr=@"日产GT-R"; NSMu ...

  2. 对Spring与SpringMVC的理解

    Spring 在我的Spring --简介及环境搭建跑通Hello提到关于Spring的基本结构与功能 SpringMVC 先上一张SpringMVC的流程图 Spring MVC 是一个模型 - 视 ...

  3. xml文件解析(使用解析器)

    一.Xml解析,解析xml并封装到list中的javabean中 OM是用与平台和语言无关的方式表示XML文档的官方W3C标准.DOM是以层次结构组织的节点或信息片断的集合.这个层次结构允许开发人员在 ...

  4. ArcGIS 网络分析[4] 网络数据集深入浅出之连通性、网络数据集的属性及转弯要素

    前面介绍完了如何创建网络数据集.如何使用网络分析功能,当然还有的读者会迷惑于一些更深层次的问题,比如网络数据集的连通性问题等. 因为不可能面面俱到,我只能挑重点来阐述,我觉得网络数据集的连通性.属性和 ...

  5. 关于table布局的推荐使用原因

    一.关于table布局的性能 1.table标签比其他html标签占用更多字节,导致下载时间延迟,占用服务器更多的流量资源: 2.table会阻碍浏览器渲染引擎的渲染顺序,导致页面生成的延迟,造成不良 ...

  6. jQuery模块化开发

    //定义了命名空间. var Itcast = {}; //定义第二级别的 命名空间. var Itcast.Model = {}; var Itcast.Model.UIJs = (function ...

  7. unity图片后期处理

    处理算法如下,在Start方法中分别调用想要的效果就行了.其中,将你需要处理的 图片 拖拽到 image参数上.注意,如果想要图片保持原来的尺寸不被压缩,需要更改图片的导入设置如下图,主要的Textu ...

  8. Mysql的硬件优化和配置优化

    mysql数据库的优化,算是一个老生常谈的问题了,网上也有很多关于各方面性能优化的例子,今天我们要谈的是MySQL硬件优化和系统参数的优化-即优化my.cnf文件 MySQL的优化我分为两个部分,一是 ...

  9. 利用伪元素:after清除浮动

    一.代码 html代码 <div class="clearfix"></div> css样式 .clearfix{ zoom:1;/*这个属性是为了兼容IE ...

  10. sql sever基本查询语句

    查询(*可代表全部)(<>代表不等于于)select 列名 from 表名(,隔开)where 查询条件order by 排序的列名+连接的数据类型必须兼容(结果为字符串数据的连接 , 如 ...