栓奶牛——二分解法

栓奶牛——二分

题目描述:
有n头奶牛,有k个木桩,每个木桩有一个位置,一个木桩上只能拴一头奶牛。由于奶牛好斗,所以在拴奶牛的时候要求距离最近的奶牛的距离尽可能大。

例如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

数据范围限制
2≤n≤100,n≤k≤100

二分算法,找到最好的mid即可

要知道,奶牛是站得越开越好,即越向右越好。

上代码:

#include<bits/stdc++.h>
using namespace std;
int n,m,k,p1[105],mod,ans,r,l=1;
int S(int o){
	int a=1,ans2,sum=0,b;
	while(a<k){
		b=a+1;
		while(b<=k&&p1[b]-p1[a]<o){
			b++;
			ans2=a; 
		}
		sum++;
		a=b;
	}
	if(p1[b]-p1[ans2]<o)
		sum--;
	if(sum+1>=n) return 1;
	else return 0;
}
int main(){
	freopen("snn.in","r",stdin);
	freopen("snn.out","w",stdout);
	scanf("%d%d%d",&n,&k,&p1[1]);
	if(n>k){
		printf("0");
		return 0;
	}
	for(int i=1;i<k;i++){
		p1[i+1]= p1[i]+((p1[i]*2357+137) % 10)+1;
	}
	r=p1[k]-p1[1];
	while(l<=r){
//		cout<<l<<' '<<r<<endl;
		int mid=(r+l)/2;
		if(S(mid)==1){
			l=mid+1;
			ans=mid;
		}

写博不易,请发现问题的大佬提出。

代码保证正确,请留赞再走。

题目描述 奶牛在数学课上学到了整除的概念。农夫 Farmer John 为了考验它的数学水平,于是在白纸上写了正整数 T。由于农夫不喜欢数字 0,所以正整数 T 是不含数字 0 的。奶牛可以删除 T 的若干位数字,剩下来的数字从左到右构成一个正整数 P,使得正整数 P 必须是 5 的倍数。奶牛有多少种不同的删除方案?具体请看样例解释。 输入格式 第一行输入一个正整数 T。 输出格式 一个整数,奶牛不同的删除方案数。 注意事项 奶牛可以删除 0 个数字(即不删除任何数字)。 奶牛不能把 T 全部删除掉。即至少要剩下 1 位数字。 由于 T 的位数可能较长,建议用字符串形式读入,详细见样例二。 输入样例一 1256 输出样例一 4 样例一解释 奶牛有 4 种不同的删除方案: 第 1 种方案:删除 T 的第四位数字,剩下的 P=125,是 5 的倍数。 第 2 种方案:删除 T 的第一位和第四位数字,剩下的 P=25,是 5 的倍数。 第 3 种方案:删除 T 的第二和第四位数字,剩下的 P=15,是 5 的倍数。 第 4 种方案:删除 T 的第一位、第二位、第四位数字,剩下的 P=5,是 5 的倍数。 输入样例二 115 输出样例二 4 样例二解释 奶牛有 4 种不同的删除方案: 第 1 种方案:不删除任何数字,剩下的 P=115,是 5 的倍数。 第 2 种方案:删除 T 的第一位数字,剩下的 P=15,是 5 的倍数。 第 3 种方案:删除 T 的第二位数字,剩下的 P=15,是 5 的倍数。 第 4 种方案:删除 T 的第一位、第二位数字,剩下的 P=5,是 5 的倍数。 温馨提示 后 6 个测试点,答案可能较大,C++ 的请用 long long 类型。 输入输出数据 1 输入数据 1 1234567899876543211234567891234667891234667895 输出数据 1 35184376291344
11-25
评论 1
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值