LibreOJ 10011 愤怒的牛 二分

农夫约翰建造了一座有 \(n\) 间牛舍的小屋,牛舍排在一条直线上,第 \(i\) 间牛舍在 \(x_i\) 的位置,但是约翰的 \(m\) 头牛对小屋很不满意,因此经常互相攻击。约翰为了防止牛之间互相伤害,因此决定把每头牛都放在离其它牛尽可能远的牛舍。也就是要最大化最近的两头牛之间的距离。

牛们并不喜欢这种布局,而且几头牛放在一个隔间里,它们就要发生争斗。为了不让牛互相伤害。John 决定自己给牛分配隔间,使任意两头牛之间的最小距离尽可能的大,那么,这个最大的最小距离是多少呢?

Solution

二分答案。当此时的距离所划分的区间多于 \(m\) 时,意味着我们可以再继续增大;否则就减小。

点击查看代码
int n,m; const int N = 1e5+5; int x[N]; int ans = 0;  bool check(int ans){     int cnt=1;     int st = x[1];     for(int i=2;i<=n;i++){         if(x[i]-st<ans)continue;         else{             cnt++;st=x[i];         }     }     if(cnt>=m)return true;     return false; }  int main(){     //ios::sync_with_stdio(false);     n = read(); m = read();     for(int i=1;i<=n;i++)x[i] = read();     sort(x+1,x+1+n);     int l=1,r = x[n];     int mid;     while(l<r){         mid = (l+r)>>1;         if(check(mid)){             l = mid+1;             ans = max(ans,mid);         }         else r = mid;     }     cout<<ans<<endl; }