20pts 求助 二分答案
查看原帖
20pts 求助 二分答案
385260
平凡天梦楼主2020/12/4 23:12
#include<iostream>
#include<cstdio>
using namespace std;

const int N=100500;
int n,m;
int a[N];
int l,r;
int c;

bool work(int k)
{
	int sum=0,b=1;
	for(int i=1;i<=n;i++)
	{
		if(sum+a[i]>k)
		{
			b++;
			sum=a[i];	
		} 
		else if(sum+a[i]==k)
		{
			b++;
			sum=0;
		}
		else
		{
			sum+=a[i];
		}
	}
	if(b<=m) return true;
	return false;
}

int main()
{
	scanf("%d%d",&n,&m);
	for(int i=1;i<=n;i++)
	{
		scanf("%d",&a[i]);
		r=max(r,r+a[i]+1);
	}
	l=1;
	while(l<=r)
	{
		int mid=(l+r)>>1;
		c=work(mid);
		if(c) r=mid-1;
		else l=mid+1;
	}
	printf("%d",l-1);
	return 0;
}
2020/12/4 23:12
加载中...