华师一附中OI组

 找回密码
 立即注册
搜索
热搜: 活动 交友 discuz
查看: 1377|回复: 2
打印 上一主题 下一主题

P1824 进击的奶牛

[复制链接]

738

主题

1485

帖子

5422

积分

管理员

Rank: 9Rank: 9Rank: 9

积分
5422
跳转到指定楼层
楼主
发表于 2018-7-24 18:25:34 | 只看该作者 回帖奖励 |正序浏览 |阅读模式
https://www.luogu.org/problemnew/show/P1824

题目描述
Farmer John建造了一个有N(2<=N<=100,000)个隔间的牛棚,这些隔间分布在一条直线上,坐标是x1,...,xN (0<=xi<=1,000,000,000)。

他的C(2<=C<=N)头牛不满于隔间的位置分布,它们为牛棚里其他的牛的存在而愤怒。为了防止牛之间的互相打斗,Farmer John想把这些牛安置在指定的隔间,所有牛中相邻两头的最近距离越大越好。那么,这个最大的最近距离是多少呢?

输入输出格式
输入格式:
第1行:两个用空格隔开的数字N和C。

第2~N+1行:每行一个整数,表示每个隔间的坐标。

输出格式:
输出只有一行,即相邻两头牛最大的最近距离。

输入输出样例
输入样例#1:
5 3
1
2
8
4
9

输出样例#1:
3

回复

使用道具 举报

9

主题

158

帖子

470

积分

华一学生

积分
470
QQ
板凳
发表于 2018-8-24 20:37:16 | 只看该作者
  1. #include<iostream>
  2. #include<algorithm>
  3. using namespace std;
  4. int n,c;
  5. int a[100001];
  6. int mid,ans;
  7. bool check(int d)
  8. {
  9.     int num=0,s=1,x=1;
  10.     while(x<n)
  11.     {
  12.         x++;
  13.         if(a[x]-a[s]<d)num++;
  14.         else s=x;
  15.     }
  16.     if(num+c<=n)return 1;
  17.     else return 0;
  18. }
  19. void ms(int l,int r)
  20. {
  21.     if(l>r)return;
  22.     mid=l+(r-l)/2;
  23.     if(check(mid))
  24.     {
  25.         ans=mid;
  26.         ms(mid+1,r);
  27.     }
  28.     else ms(l,mid-1);
  29. }
  30. int main()
  31. {
  32.     cin>>n>>c;
  33.     for(int i=1;i<=n;i++)cin>>a[i];
  34.     sort(a+1,a+n+1);
  35.     ms(1,a[n]);
  36.     cout<<ans;
  37.     return 0;
  38. }
复制代码
回复 支持 反对

使用道具 举报

2

主题

105

帖子

306

积分

中级会员

Rank: 3Rank: 3

积分
306
沙发
发表于 2018-7-25 10:17:11 | 只看该作者
  1. #include <algorithm>
  2. #include <iostream>
  3. #include <cmath>
  4. #include <cstring>
  5. #include <map>
  6. #include <string>
  7. #include <vector>
  8. #include <queue>
  9. #include <stack>
  10. #include <cstdio>
  11. #include <cstdlib>
  12. using namespace std;
  13. int n,m,a[100011];
  14. bool check(int jian)
  15. {
  16.         int all=1,last=a[1];
  17.         for(int i=2;i<=n;i++)
  18.         {
  19.                 if(a[i]-last>=jian)
  20.                         all++,last=a[i];
  21.                 if(all>=m)
  22.                         return true;
  23.         }
  24.         return false;
  25. }
  26. int main()
  27. {
  28.         scanf("%d%d",&n,&m);
  29.         for(int i=1;i<=n;i++)
  30.                 scanf("%d",&a[i]);
  31.         sort(a+1,a+1+n);
  32.         int l=1,r=a[n]-a[1];
  33.         while(l<r)
  34.         {
  35.                 int mid=(l+r+1)>>1;
  36.                 if(check(mid)) l=mid;
  37.                 else r=mid-1;
  38.         }
  39.         printf("%d",l);
  40.         return 0;
  41. }
复制代码
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

QQ|Archiver|手机版|小黑屋|服务支持:DZ动力|华师一附中OI组  

GMT+8, 2024-12-26 13:24 , Processed in 0.163616 second(s), 26 queries .

Powered by Discuz! X3.2

© 2001-2013 Comsenz Inc.

快速回复 返回顶部 返回列表