社区讨论

60分蒟蒻求助

P2678[NOIP 2015 提高组] 跳石头参与者 1已保存回复 0

讨论操作

快速查看讨论及其快照的属性,并进行相关操作。

当前回复
0 条
当前快照
1 份
快照标识符
@lq96h8k5
此快照首次捕获于
2023/12/17 15:41
2 年前
此快照最后确认于
2023/12/17 17:17
2 年前
查看原帖
CPP
#include<bits/stdc++.h>
using namespace std;
long long int r,l,p,m,q,k,n[50005],mid,sum,last;
bool f(int x)
{
	long long int ans=0;
	last=0;
	for(long long int i=1;i<=q+1;i++)
	{
		if(n[i]-n[last]<x)
		{
			
				ans++;
		}
		else
		{
			last=i;
		}
	}
	return ans<=p;
}
int main(){
	ios_base::sync_with_stdio(false);
	cin>>m>>q>>p;
	for(int i=1;i<=q;i++)
	{
		cin>>n[i];
	}
	n[q+1]=m;
	l=1;
	r=q+1;
	while(l<=r)
	{
		mid=(l+r)/2;
		if(f(mid))
		{
			sum=mid;
			l=mid+1;
		}
		else
			r=mid-1;
	}
	cout<<sum;
	return 0;
}

回复

0 条回复,欢迎继续交流。

正在加载回复...