Submission #1135240

#TimeUsernameProblemLanguageResultExecution timeMemory
1135240hamzabcBigger segments (IZhO19_segments)C++20
100 / 100
49 ms16052 KiB
#include <bits/stdc++.h> using namespace std; #define all(x) x.begin(), x.end() #define mod 1000000007 #define sp << " " << #define endl << '\n' long long int N; signed main() { ios_base::sync_with_stdio(false); cin.tie(0); cout.tie(0); cin >> N; vector<long long int> lst(N), p(N, -1), out(N); long long int *prefix = new long long int[N + 1]; prefix[0] = 0; prefix++; for (int i = 0; i < N; i++){ cin >> lst[i]; prefix[i] = lst[i]; prefix[i] += prefix[i - 1]; } for (int i = 0; i < N; i++){ auto k = lower_bound(prefix + i, prefix + N, prefix[i] * 2 - prefix[p[i]]); if (k != prefix + N){ p[k - prefix] = i; out[k - prefix] = out[i] + 1; } if (i != N - 1){ if (out[i] > out[i + 1]){ p[i + 1] = p[i]; out[i + 1] = out[i]; }else{ p[i + 1] = max(p[i + 1], p[i]); } } } cout << out[N - 1] + 1; 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...