8 条题解

  • 0
    @ 2023-5-28 10:02:07

    #include<bits/stdc++.h> using namespace std; #define ll long long const int N=1e5+10; const int INF=0x3f3f3f3f; int n,m,a[N],l,r,ans; bool check(int mid){ int sum=0,num=1; for(int i=1;i<=n;i++){ if(sum+a[i]<=mid){ sum+=a[i]; }else{ num++; sum=a[i]; } } return num<=m; } signed main(){ cin>>n>>m; for(int i=1;i<=n;i++){ cin>>a[i]; l=max(l,a[i]); r+=a[i]; } while(l<=r){ int mid=(l+r)/2; if(check(mid)){ ans=mid; r=mid-1; }else{ l=mid+1; } } cout<<ans; return 0; }

    信息

    ID
    360
    时间
    1000ms
    内存
    512MiB
    难度
    6
    标签
    递交数
    313
    已通过
    97
    上传者