제출 #712178

#제출 시각아이디문제언어결과실행 시간메모리
712178PherokungBigger segments (IZhO19_segments)C++14
100 / 100
366 ms44188 KiB
#include<bits/stdc++.h>
using namespace std;
#define ll long long
#define F first
#define S second
typedef pair<ll,ll> pa;
ll n,a,qs[500005],dp[500005],l,r,p,v;
set<pa> s;
set<pa> :: iterator it;
ll rang(int l,int r){
	return qs[r] - qs[l-1];
}
int main(){
	scanf("%lld",&n);
	for(int i=1;i<=n;i++){
		scanf("%lld",&a);
		qs[i] = qs[i-1]+a;
	}
	s.insert({0,0});
	
	for(int i=1;i<=n;i++){
		it = s.upper_bound({qs[i],1e18});
		--it;
		v = (*it).F, p = (*it).S;
		dp[i] = dp[p] + 1;
		it = s.lower_bound({qs[i] + rang(p+1,i),-1e18});
		
		s.erase(it,s.end());
		s.insert({qs[i] + rang(p+1,i),i});
	}
	
	printf("%lld",dp[n]);
}

컴파일 시 표준 에러 (stderr) 메시지

segments.cpp: In function 'int main()':
segments.cpp:14:7: warning: ignoring return value of 'int scanf(const char*, ...)' declared with attribute 'warn_unused_result' [-Wunused-result]
   14 |  scanf("%lld",&n);
      |  ~~~~~^~~~~~~~~~~
segments.cpp:16:8: warning: ignoring return value of 'int scanf(const char*, ...)' declared with attribute 'warn_unused_result' [-Wunused-result]
   16 |   scanf("%lld",&a);
      |   ~~~~~^~~~~~~~~~~
#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...