蒟蒻求助P2678
  • 板块灌水区
  • 楼主星空舞涵
  • 当前回复3
  • 已保存回复3
  • 发布时间2020/9/1 10:46
  • 上次更新2023/11/5 13:51:32
查看原帖
蒟蒻求助P2678
243750
星空舞涵楼主2020/9/1 10:46
#include<bits/stdc++.h>
using namespace std;
long long n,m,d;
int a[500005],ans;
int tiao(int x)
{
	int tot=0,num=0,now=0;
	while(num<n+1)
	{
		num++;
		if(a[num]-a[now]<x)
		{
			tot++;
		}
		else 
		{
			now=num;
		}
	}
	if(tot>m)	return 0;
	return 1;
}
int main()
{
	cin>>d>>n>>m;
	for(int i=1;i<=n;i++)	cin>>a[i];
	a[n+1]=d;
	int l=1;int r=d;
	while(l<=r)
	{
		int mid=(l+r)/2;
		if(tiao(mid)==1)
		{
			ans=mid;
			l=mid+1;
		}
		else r=mid-1;
	}
	cout<<ans;
}

为什么l=mid+1,r=mid-1,如果不减的话为啥会T掉

2020/9/1 10:46
加载中...