Aggressive cows

题目地址:点击

#include <iostream>
#include <cstring>
#include <algorithm>
using namespace std;

int stall[100005];
bool judge(int n,int c,int distance){       //distance是当前最小距离,函数判断此距离是否满足放下所有牛
    int x=stall[0];     //当前放牛的位置
    int num=1;      //已经放了多少牛
    for(int i=1;i<n;i++){
        if(stall[i]-x>=distance){       //如果要放的牛的位置>=要求的距离
            x=stall[i];         //改变当前牛在的位置
            num++;      //数量加1
            /*此if一旦满足,则立即放入牛,保证了两头牛之间是最小距离
            */
        }
        if(num>=c)      //所有牛都在最小距离内放完,以为当前distance(最小距离)是满足要求。
            return 1;
    }
    return 0;
}

int main(){
    int n,c;
    cin>>n>>c;
    for(int i=0;i<n;i++)
        scanf("%d",&stall[i]);
    sort(stall,stall+n);
    int low=1,high=stall[n-1]-stall[0];     //low,high是能取到的小和最大距离
    while(low<=high){
        int mid=(low+high)/2;
        if(judge(n,c,mid)){    //当前的距离可行,因为求最大的最小距离,需要将距离调大
            low=mid+1;  
        }
        else{       //当前距离无法装下所有牛,调小距离
            high=mid-1;
        }
    }
    cout<<high;     //当while循环时到low=high,则mid=low=high。当mid可行时,low=high+1,则high是合法的;
                    //当mid不可行时,意味着low就是不可行,此时high=low-1后,为可行。
    return 0;

}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值