poj2456---Aggressive cows

news/2024/7/8 2:47:53

tips:

  1.二分时区间是否要加等号,看等号成立时是否需要进入循环

  2.L和R的赋值要看条件,第一个满足条件和最后一个满足条件

  3.所有的都可以归结为找位置??

//感觉是二分答案
//想要寻找最后一个满足条件C的元素的位置,
//可以寻找第一个满足条件!C的位置,然后将盖位置减一
//left==right 意味着找到唯一位置,相等时不用再进入循环
//ref:算法笔记
#include <cstdio>
#include<algorithm>
using namespace std;
const int M=100010;
const double eps=1e-5;
int n,c;
int a[M];
int judge(int x){
    int ans=1;
    int tmp=a[0];
    for(int i=1;i<n;i++){
        if(a[i]-tmp>= x){
            ans++;
            tmp=a[i];
        }
    }
    return ans;
}
int main(){
    while(scanf("%d%d",&n,&c)!=EOF){
        for(int i=0;i<n;i++){
            scanf("%d",&a[i]);
        }
        sort(a,a+n);
        int L=0;
        int R=a[n-1]-a[0];
        while(L<R){
            int mid=L+(R-L)/2;
            if(judge(mid) < c)
                R=mid;
            else
                L=mid+1;
        }
        printf("%d\n",L-1);

    }
    return 0;
}
View Code

 

转载于:https://www.cnblogs.com/SUMaywlx/p/9471703.html


http://www.niftyadmin.cn/n/4557416.html

相关文章

Tomcat在阿里云上启动慢的解决办法

omcat在本地服务器跑&#xff0c;一切都正常&#xff0c;但部署到阿里云上&#xff0c;发现启动巨慢。 经过在网上搜索&#xff0c;找到了原因&#xff1a; Tomcat 7/8都使用org.apache.catalina.util.SessionIdGeneratorBase.createSecureRandom类产生安全随机类SecureRandom的…

哪里有c++的学习方法

||| 有本书很好《The C Programming Language》 你一定会成功的 好好学吧 好了 学c就变得很容易了 如果有点c的底子 直接学c就可以了 对于你来说 还是直接就学c 你也就喜欢上它了&#xff1b;其实无论是先学c 慢慢的就会好起来了 然后在运行自己的小程序 多运行几次别人的程序 …

AQS同步器的实现原理

1.什么是AQS? AQS的核心思想是基于volatile int state这样的volatile变量&#xff0c;配合Unsafe工具对其原子性的操作来实现对当前锁状态进行修改。同步器内部依赖一个FIFO的双向队列来完成资源获取线程的排队工作。 2.同步器的应用 同步器主要使用方式是继承&#xff0c;子类…

MySQL引用完整性约束

一、定义 引用完整性是对实体之间关系的描述&#xff0c;是定义外关键字与主关键字之间的引用规则&#xff0c;也就是外键约束。如果要删除被引用的对象&#xff0c;也要删除引用它的所有对象&#xff0c;或把引用值设置为空。外键指引用另一个表中的一列或多列&#xff0c;被…

noip允许使用什么头文件

流 相关的头文件&#xff1a;<bitset><iterator><string><iostream> 2.禁止使用的部分 序列&#xff1a;vector stdio.h ||| 到底是C 还是C 呀 你列的中: stdlib.h 是 C 的 串 迭代器 priority_queue ... 答案补充 C语言的stdio.h能用不过我建议你用C …

bzoj 1001 [BeiJing2006]狼抓兔子 最小割+最短路

题面 题目传送门 解法 将最大流转化成最小割&#xff0c;然后跑最短路即可 具体如何见图可以参考下图 尽量用dijkstra 代码 #include <bits/stdc.h> #define PI pair <int, int> #define mp make_pair #define N 1010 using namespace std; template <typename …

自定义tomcat实现

一、tomcat基础 1.基础功能 提供Socket服务&#xff1a;实现对某些端口的监听&#xff0c;从而实现请求到来时&#xff0c;Tomcat可以感知到。同时该Socket服务也需要支持HTTP协议。封装请求和响应&#xff1a;通过之前的介绍&#xff0c;我们知道在我们开发Servlet时&#x…

C语言中关于取三位数的各各位数的单个数字问题

在BCB下 19 了 ||| 367除以100 3367除以10取10余6367取10余7 3 18 2 1)就是6 a[j]); }} ||| 位置是固定的 只需要判断/0的位置就可以 ||| #include <stdio.h>main(){ int a[3]; int i 0; int j; int numb 123; while(numb char a[10];scanf("%s" 如果你输入的…