【洛谷】进击的奶牛

进击的奶牛

题目链接

题意

输出相邻两头牛最大的最近距离

思路

运用二分的方法来查找最大的距离,由题意可知,我们最后输出的结果是区间的右边,即r

实现步骤
  1. 先用check函数来对距离判断,如果两头牛之间的距离大于了我们给定的距离,那么我们把d存在数组里面
  2. 在主函数中输入所需值,定义左右两边的边界值,套用二分模板来进行计算(模板二:从右边开始找答案)
  3. 最后输出结果即可,但要注意我们输出的是最大距离,不要输出 l ,应该输出 r
代码
cpp 复制代码
#include<bits/stdc++.h>
using namespace std;
const int N=1e9+10;
int n,k,a[N],ans;
bool check(int x)
{
	int d=a[1],sum=1;
	for(int i=2;i<=n;i++)
	{
		if(a[i]-d>=x)
		{
			sum++;
			d=a[i];
		} 
	}
	return sum>=k;
}
int main()
{
	cin>>n>>k;
	for(int i=1;i<=n;i++)
	{
		cin>>a[i];
	}
	int l=1,r=N;
	sort(a+1,a+n+1);
	while(l<=r)
	{
		int m=l+r>>1;
		if(check(m))
		{
			ans=m;
			l=m+1;
		}
		else
		{
			r=m-1;
		}
	}
	cout<<ans;
	return 0;
} 
 

总结

二分

相关推荐
汉克老师20 小时前
GESP2025年3月认证C++五级( 第三部分编程题(2、原根判断))
c++·算法·模运算·gesp5级·gesp五级·原根·分解质因数
数据皮皮侠21 小时前
上市公司创新韧性数据(2000-2024)|顶刊同款 EIR 指数
大数据·人工智能·算法·智慧城市·制造
WL_Aurora21 小时前
Python 算法基础篇之链表
python·算法·链表
科研前沿21 小时前
纯视觉无感解算 + 动态数字孪生:室内外无感定位技术全新升级
大数据·人工智能·算法·重构·空间计算
Wadli21 小时前
26.单调栈
算法
晨曦夜月21 小时前
进程的五大状态及特殊进程解析
linux·服务器·算法
吟安安安安1 天前
适合短期冲刺的学习工作流(针对算法)
学习·算法
科研前沿1 天前
什么是时空融合技术?
大数据·人工智能·数码相机·算法·重构·空间计算
AI科技星1 天前
全域数学本源公理:0、1、∞ 三者核心关系 (典籍定稿版)
人工智能·算法·数学建模·数据挖掘·量子计算
AI科技星1 天前
全域数学·第卷:场计算机卷(场空间计算机)【乖乖数学】
java·开发语言·人工智能·算法·机器学习·数学建模·数据挖掘