码迷,mamicode.com
首页 > 其他好文 > 详细

codevs 4768 跳石头

时间:2016-05-21 10:04:28      阅读:134      评论:0      收藏:0      [点我收藏+]

标签:

传送门

表示去年不会,二分是啥都不知道,一脸懵逼。

今年再做,虽然知道二分是啥了,但依旧不会,蒙蔽了好几天,最后还是看了题解。

 

#include<cstdio>
#define M 51000
int n,m,ans=0,L;
int a[M];
void find(int l,int r)
{
if (l>r) return;//我做了无数遍,这句话毁了我一生。
/*
当l<=r时,可能查到的不是最小值中的最大值,继续向下查询。
只有当l>r时,说明上一步查的是最大值。
*/
int mid=(l+r+1)/2,k=0,sum=0;
int bj[M];
bj[++k]=0;
for (int i=1;i<=n;i++)
if (a[i]-a[bj[k]]>=mid) bj[++k]=i;
else sum++;
while (L-a[bj[k]]<mid) sum++,k--;
if (sum>m) find(l,mid-1);
else ans=mid,find(mid+1,r);
}

int main()
{
scanf("%d%d%d",&L,&n,&m);
for (int i=1;i<=n;i++)
scanf("%d",&a[i]);
find(0,L);
printf("%d",ans);
return 0;
}

 

codevs 4768 跳石头

标签:

原文地址:http://www.cnblogs.com/sjymj/p/5514057.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!