【洛谷】进击的奶牛

进击的奶牛

题目链接

题意

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

思路

运用二分的方法来查找最大的距离,由题意可知,我们最后输出的结果是区间的右边,即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;
} 
 

总结

二分

相关推荐
团象科技18 分钟前
走访近百支出海技术团队后的海外云计算资源选型实操观察
大数据·人工智能·算法
勤自省35 分钟前
吴恩达机器学习课程实验:线性回归模型入门(课后实验)
人工智能·算法·机器学习·回归·线性回归
ChillCoding40 分钟前
更新中:C++ STL库,查找排序(基础算法),数据结构,数学算法,竞赛相关基础
数据结构·c++·算法
智者知已应修善业1 小时前
【51单片机使用IO组赋值方法实现无源蜂鸣器响时LED12亮不响时34亮】2024-3-7
c++·经验分享·笔记·算法·51单片机
珊瑚里的鱼1 小时前
【动态规划】按摩师
算法·动态规划
Fms_Sa1 小时前
贪心算法-背包问题
算法·贪心算法·c#
大雨淅淅1 小时前
【机器人】ROS2 机械臂控制(MoveIt2)从入门到实战
人工智能·python·神经网络·学习·算法·机器学习·机器人
智者知已应修善业2 小时前
【51单片机0.1秒计时到21.0时点亮LED】2024-1-5
c++·经验分享·笔记·算法·51单片机
apcipot_rain2 小时前
计科八股20260606——二叉树、PCA、图深度学习、进程上下文、C语言预编译、文件读写、单精度浮点数
c语言·数据结构·算法·pca·图神经网络
scx_link2 小时前
逻辑回归的总结
算法·机器学习·逻辑回归