This submission is migrated from previous version of oj.uz, which used different machine for grading. This submission may have different result if resubmitted.
#include<bits/stdc++.h>
using namespace std;
using ll=long long;
ll a[500005],qs[500005];
struct A{
int cnt;
ll val;
A(int cnt_=0,ll val_=0):cnt(cnt_),val(val_){}
bool operator<(const A&o)const{
if(cnt!=o.cnt) return cnt>o.cnt;
return val<o.val;
}
}dp[500005];
int main(){
ios::sync_with_stdio(false); cin.tie(0);
int n; cin>>n;
for(int i=1;i<=n;++i){
cin>>a[i];
qs[i]=qs[i-1]+a[i];
}
for(int i=1;i<=n;++i){
for(int j=1;j<=i;++j){
if(qs[i]-qs[j-1]>=dp[j-1].val) dp[i]=min(dp[i],A(dp[j-1].cnt+1,qs[i]-qs[j-1]));
}
}
cout<<dp[n].cnt;
return 0;
}
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |