博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Glider Gym - 101911B(二分+前缀和)
阅读量:4701 次
发布时间:2019-06-09

本文共 893 字,大约阅读时间需要 2 分钟。

没一个x降1个y 所以对于高度H 不在上升区最多走在x方向走H

a[]存上升区的前缀和

b[]存非上升区的前缀和

对于每个b[i]+h二分查找对应的点;

a[pos-1]-a[i-1]就是其经过的上升区的长度

维护最大值

ans+H 即为答案

#include
#define mem(a,b) memset(a,b,sizeof(a))#define sc(x) scanf("%lld",&(x))#define inf 0x3f3f3f3f#define ll long long#define int long longusing namespace std;const int maxn=2e5+10;struct node{ int l,r;}e[maxn];int a[maxn],b[maxn];#undef intint main(){#define int long long int n,h; sc(n),sc(h); e[0].r=0; int l,r; cin>>l>>r; e[1]=(node){l,r}; a[1]=r-l; b[1]=0; for(int i=2;i<=n;i++) { sc(l),sc(r); a[i]=a[i-1]+r-l; b[i]=b[i-1]+l-e[i-1].r; e[i]=(node){l,r}; } b[n+1]=inf; int ans=0; for(int i=1;i<=n;i++) { int pos=lower_bound(b+1,b+1+n,b[i]+h)-b; ans=max(ans,a[pos-1]-a[i-1]); } cout<
<

 

转载于:https://www.cnblogs.com/minun/p/11282255.html

你可能感兴趣的文章
String类的深入学习与理解
查看>>
不把DB放进容器的理由
查看>>
OnePage收集
查看>>
Java parseInt()方法
查看>>
yahoo的30条优化规则
查看>>
[CCF2015.09]题解
查看>>
[NYIST15]括号匹配(二)(区间dp)
查看>>
json_value.cpp : fatal error C1083: 无法打开编译器生成的文件:No such file or directory
查看>>
洛谷 P1101 单词方阵
查看>>
Swift DispatchQueue
查看>>
C#和JAVA 访问修饰符
查看>>
小甲鱼OD学习第1讲
查看>>
HDU-1085 Holding Bin-Laden Captive-母函数
查看>>
php提示undefined index的几种解决方法
查看>>
LRJ
查看>>
Struts2环境搭建
查看>>
Linux: Check version info
查看>>
stl学习之测试stlen,cout等的运行速度
查看>>
魔戒三曲,黑暗散去;人皇加冕,光明归来
查看>>
Error和Exception
查看>>