Run ID | 作者 | 问题 | 语言 | 测评结果 | 分数 | 时间 | 内存 | 代码长度 | 提交时间 |
---|---|---|---|---|---|---|---|---|---|
109596 | 凌艺樽 | 花费 | C++ | 解答错误 | 10 | 0 MS | 256 KB | 612 | 2023-11-09 20:41:03 |
#include <bits/stdc++.h> using namespace std; const int N=1e5+10; const int INF=0x3f3f3f3f; long long maxx; int minn=INF; int a[N],n,m; bool check(long long x) { int sum=0,f=0; for(int i=1;i<=n;i++) { if(sum+a[i]>x) { f++; sum=a[i]; } else { sum+=a[i]; } } return f<=m; } int main() { cin>>n>>m; for(int i=1;i<=n;i++) { cin>>a[i]; maxx+=a[i]; minn=min(minn,a[i]); } long long l=minn,r=maxx; while(l<r) { long long mid=l+r>>1; if(check(mid)) r=mid; else l=mid+1; } cout<<r; return 0; }