Submission #1058919

#TimeUsernameProblemLanguageResultExecution timeMemory
1058919vjudge1Bigger segments (IZhO19_segments)C++17
0 / 100
0 ms348 KiB
#include <bits/stdc++.h> #ifdef LOCAL #include "/home/trcmai/code/tools.h" #define debug(x...) cerr << "\e[91m"<<__func__<<":"<<__LINE__<<" [" << #x << "] = ["; _print(x); cerr << "\e[39m" << endl; #else #define debug(x...) #endif using namespace std; #define all(a) a.begin(), a.end() #define ll long long #define endl '\n' const int N = 1e6 + 6, LOG = 27, MOD = 1e9 + 7; const ll INF = 1e18; int n; //Dynamic Segtree struct segtree { struct node {ll v, l, r; node() {v = 0; l = -1, r = -1;}}; vector<node> st; segtree() {st.clear(); st.push_back(node());}; void update(ll id, ll l, ll r, ll i, ll x) { if (l == r) {st[id].v += x; return;} ll m = (r+l)>>1; st[id].v = max(st[id].v,x); if (l <= i && i <= m) { if (st[id].l == -1) {st[id].l = st.size(); st.push_back(node());} update(st[id].l,l,m,i,x); } if (m < i && i <= r) { if (st[id].r == -1) {st[id].r = st.size(); st.push_back(node());} update(st[id].r,m+1,r,i,x); } } ll get(ll id, ll l, ll r, ll u, ll v) { if (r < u || v < l) return 0; if (u <= l && r <= v) return st[id].v; ll m = (r+l)>>1, val = 0; if (st[id].l != -1) val = max(val,get(st[id].l,l,m,u,v)); if (st[id].r != -1) val = max(val,get(st[id].r,m+1,r,u,v)); return val; } void update(ll i, ll x) {update(0,-1e15,1e15,i,x);} ll get(ll u, ll v) {return get(0,-1e15,1e15,u,v);} } st; signed main() { cin.tie(0)->sync_with_stdio(0); auto solver=[&](){ cin>>n; vector<ll>a(n + 1),dp(n + 1),opt(n + 1); for(int i = 1;i <= n;++i){ cin>>a[i]; a[i] += a[i - 1]; } segtree st; for(int i = 1;i <= n;++i){ int j = st.get(0,a[i]); dp[i] = dp[j] + 1; opt[i] = a[i] - a[j]; st.update(opt[i] + a[i],i); } cout<<dp[n]<<endl; }; int t = 1; // cin>>t; while (t--) solver(); }
#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...