首页 > 其他分享 >洛谷p1824 进击的奶牛

洛谷p1824 进击的奶牛

时间:2023-08-29 19:44:42浏览次数:32  
标签:洛谷 进击 样例 int p1824 return 牛栏 check

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

做法:二分答案

思路:先sort 取left=a[0],right=a[N-1],mid=(left+right)/2进行二分查找。

 

check函数用来判断当前长度是否符合要求,即在当前牛栏间隔下,使用的牛栏是否小于总牛栏数-牛数。

bool check(int x){
    int tmp=a[0];
    int cnt=0;
    for (int i=1;i<N;i++) {
        if (a[i] - tmp < x)
            cnt++;
        else
            tmp = a[i];
    }
    if (cnt>N-C) return false;
    else return true;
}

AC代码:

注意二分判断条件中<=号。

#include <bits/stdc++.h>
using namespace std;
int N,C;
const int maxN=1e5+1;
int a[maxN];

bool check(int x){
    int tmp=a[0];
    int cnt=0;
    for (int i=1;i<N;i++) {
        if (a[i] - tmp < x)
            cnt++;
        else
            tmp = a[i];
    }
    if (cnt>N-C) return false;
    else return true;
}

int main(){
    cin>>N>>C;
    for (int i=0;i<N;i++)
        cin>>a[i];
    sort(a,a+N);
    int l=a[0],r=a[N-1];
    while (l<=r){
        int mid=(r+l)/2;
//        cout<<mid<<endl;
        if (check(mid)) l=mid+1;
        else r=mid-1;
    }
    cout<<l-1;
    return 0;
}

 

标签:洛谷,进击,样例,int,p1824,return,牛栏,check
From: https://www.cnblogs.com/aomiao/p/17664838.html

相关文章

  • 洛谷P1013 [NOIP1998 提高组] 进制位
    P1013[NOIP1998提高组]进制位P1013题目传送门这是一道提高+/省选-的蓝题,有亿点点难度,我们先分析一下。分析字母的数量等于进制的大小,判错的时候,可以看一下那个表格右下角的一个等腰三角形,就会发现有一个由两位字母组成的三角形。我们验算一下,对于\(L\),在该三角形的双位字......
  • 洛谷P5865 [SEERC2018] Tree
    P5865[SEERC2018]Tree题目传送门分析本题不难,只要枚举即可。假设两点之间的距离为树的端点,然后再去枚举其他点,符合的加入集合。若黑色点的个数超出了定义个数,那么就更新一遍。最后求最小值。ACCode:#include<bits/stdc++.h>//保命万能头usingnamespacestd;//命名空......
  • 【LGR-156-Div.3】洛谷网校 8 月普及组月赛 I & MXOI Round 1 & 飞熊杯 #2(同步赛)
    【LGR-156-Div.3】洛谷网校8月普及组月赛I&MXOIRound1&飞熊杯#2(同步赛)\(T1\)luoguP9581宝箱\(100pts\)水题,模拟即可。intmain(){ inta,b,ans=0; cin>>a>>b; if((a<0&&b<0)||(a>0&&b>0)) { cout<<max(abs(a),abs......
  • 【主席树】洛谷 P3834 可持久化线段树 2
    【主席树】洛谷P3834可持久化线段树2题目链接:https://www.luogu.com.cn/problem/P3834主席树是可持久化线段树的一种,也叫做可持久化权值线段树,主要可以用来O(logn)求静态区间的第k小数。总所周知,普通线段树每次修改会遍历logn个点,那么我们在每次修改时都把这logn个点复制一份......
  • 洛谷100题计划 (15/100)
    洛谷100题计划(15/100)P1094[NOIP2007普及组]纪念品分组-洛谷|计算机科学教育新生态(luogu.com.cn)要使得分组最少,其实就是要让一个大的和一个小的放一起,如果大的和小的一起放超过了\(w\),那大的就应该单独放,所以排完序之后,我们可以用双指针从两边寻找可以放一起的......
  • 洛谷100题计划(10/100)
    洛谷100题计划(10/100)P1031[NOIP2002提高组]均分纸牌-洛谷|计算机科学教育新生态(luogu.com.cn)因为第\(1\)堆只能移动到第\(2\)堆,且第\(N\)堆只能移动到第\(N-1\)堆,所以直接从左边往右边转移就行,这里是都减了一个平均数,看所有堆都差多少,如果左右两个都没过平均数......
  • 【题解】洛谷 P1002 [NOIP2002 普及组] 过河卒
    原题链接解题思路这是一道经典的动态规划题目。如果尝试使用深度优先搜索(dfs)或广度优先搜索(bfs)做就会获得TLE(注意数据范围)。于是我们想到了更为高级的动态规划(DynamicProgramming,dp)。简略介绍动态规划算法的核心思想:把原问题分解为相对简单的子问题的方式求解复杂问题。......
  • 洛谷集合题单
    发现自己的基础代码能力还有待提高【数据结构1-3】集合-题单-洛谷|计算机科学教育新生态(luogu.com.cn)P5250【深基17.例5】木材仓库-洛谷|计算机科学教育新生态(luogu.com.cn)学习set的使用搬个知乎的STL教程(九):C++STL常用容器之set/multiset-知乎(zhihu.c......
  • 树链剖分 | 洛谷 P4114 Qtree1
    前言题目链接:洛谷P4114Qtree1前置知识:树链剖分题意给定一棵树,有修改边权和查询两点之间边权最大值两种操作,对于每个查询输出结果。解析已经在前置博客里提到,树链剖分可以将树上的任意一条路径划分成不超过\(O(\logn)\)条连续的链,保证划分出的每条链上的节点DFS序......
  • 普及模拟2 +【LGR-155-Div.3】洛谷基础赛 #3 &「NnOI」Round 2
    普及模拟2\(T1\)地址\(0pts\)简化题意:判断一个\(IP\)地址是否合法(数据保证字符串中存在且仅存在4个被字符分开的整数)#include<bits/stdc++.h>usingnamespacestd;#definelllonglong#definesortstable_sort#defineendl'\n'chars[100];intmain(){ freope......