拴奶牛

拴奶牛

题目描述
有n头奶牛(2≤n≤100),有k个木桩(n≤k≤100),每个木桩有一个位置,一个木桩上只能拴一头奶牛。由于奶牛好斗,所以在拴奶牛的时候要求距离最近的奶牛的距离尽可能大。
例如n=4,k=6,木桩的位置为0,3,4,7,8,9(如最下面的图)
此时,有许多拴牛方案,例如
0,3,4,9      此时最近距离为1(3,4之间)
0,3,7,9      此时最近距离为2
 

输入
n,k,p1三个整数(0≤p1≤100),其中p1为第1个木桩的位置,其他木桩pi(i≥2)的位置由下面公式算出:p[i]= p[i-1]+((p[i-1]*2357+137) mod 10)+1  

输出
一个整数,即奶牛最近距离的最大值。

样例输入
25 70 99

样例输出
12

这题其实非常简单,
我是直接用二分枚举在判断一下方案是否成立就过了
核心代码二分查找:

int l=1;
int r=p[k]-p[1],ans;
while(l<=r)
{
	int mid=(r+l)/2;
	if(ss(mid))
	{	
		l=mid+1;
		ans=mid;
	}
	else
		r=mid-1;
}

这里用二分枚举了最近距离的值。
用ss函数来判断最近距离的值是否成立。
ss函数要自己定义
用两个while循环来实现
这样的话时间复杂度最坏是O(k^2*log(n));

ss函数

第一层循环判断是否还有剩下的位置,第二层循环判断后面循环的木桩是否还有位置与第一层循环的木桩与第二层循环的木桩的差值是否小于最近距离的最大值。ans在主函数中定义为局部变量,ans在pk函数中定义为能栓的最大奶牛数,最后判断ans是否满足栓n只奶牛return最后判断的结果。即可实现判断最近距离的值是否成立的效果。ant是用来存最后一个间距开始木桩的编号。

bool ss(int t)
{
	int ow=1,ans=1,next;
	while(ow<k)
	{
		next=ow+1;
		while(next<=k&&p[next]-p[ow]<t)
		{
			next++;
			ant=ow;
		}
		ans++;
		ow=next;
	}
	if(p[next]-p[ant]<t)
		ans--;
	return ans>=n;
}
  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值