제출 #889282

#제출 시각아이디문제언어결과실행 시간메모리
889282kimBigger segments (IZhO19_segments)C++17
37 / 100
1561 ms15196 KiB
#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 timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...