Submission #844971

#TimeUsernameProblemLanguageResultExecution timeMemory
844971hentai_loverBigger segments (IZhO19_segments)C++14
Compilation error
0 ms0 KiB
#include <bits/stdc++.h> using namespace std; typedef long long ll; const long long oo = 1LL * 1e14; struct kek{ int l = -1; int r = -1; pair<int, int> ans; } emp; struct ST{ vector<kek> t; void uni(){ t.push_back(emp); } void upd(ll poz, pair<int,int> val, int v = 0, ll l = 0, ll r = oo){ if(poz < 0)return; if(l == r){t[v].ans = val;return;} ll c = (l + r)>>1; if(t[v].l < 0){t[v].l = t.size(); t.push_back(emp);} if(t[v].r < 0){t[v].r = t.size(); t.push_back(emp);} if(poz <= c)upd(poz, val, t[v].l, l, c); else upd(poz, val, t[v].r, c + 1, r); t[v].ans = max(t[t[v].l].ans, t[t[v].r].ans); } pair<int, int> get(ll l, ll r, int v = 0, ll tl = 0, ll tr = oo){ if(l > r)return {-228, -228}; if(tl == l && tr == r)return t[v].ans; ll c = (tl + tr) >> 1; if(t[v].l < 0){t[v].l = t.size(); t.push_back(emp);} if(t[v].r < 0){t[v].r = t.size(); t.push_back(emp);} //pair<int,int> a = get(l, min(r, c), t[v].l, tl, c); //pair<int,int> b = get(max(l, c + 1), r, t[v].r, c + 1, tr); //if(a.second > b.second)return a; //return b; return max(a, b); return max(get(l, min(r, c), t[v].l, tl, c), get(max(l, c + 1), r, t[v].r, c + 1, tr)); } }; int32_t main() { ios_base::sync_with_stdio(0); //cout<<oo<<endl; int n; cin>>n; int a[n]; for(int i = 0; i < n; i += 1)cin>>a[i]; ll sf[n + 1] = {}; for(int i = n - 1; i >= 0; i -= 1)sf[i] = sf[i + 1] + a[i]; ///dp[p] = {ans, min_sum} pair<int,ll> dp[n]; ll sum = 0; for(int i = 0; i < n; i += 1){ sum += a[i]; dp[i] = {1, sum}; } ST tree; tree.uni(); tree.upd(sf[1] - dp[0].second, {1, 0}); for(int i = 1; i < n; i += 1){ pair<int,int>temp = tree.get(sf[i + 1], oo); //cerr<<"i = "<<i<<" temp: "<<temp.first<<" "<<temp.second<<endl; dp[i] = max(dp[i], {temp.first + 1, sf[temp.second + 1] - sf[i + 1]}); tree.upd(sf[i + 1] - dp[i].second, {dp[i].first, i}); } // cout<<"dp:"; // for(int i = 0; i < n; i += 1)cout<<dp[i].first<<' '<<dp[i].second<<endl; int ans = 0; for(int i = 0; i < n; i += 1){ ans = max(ans, dp[i].first); } cout<<ans; } /* 5 6 2 3 9 13 */

Compilation message (stderr)

segments.cpp: In member function 'std::pair<int, int> ST::get(ll, ll, int, ll, ll)':
segments.cpp:47:20: error: 'a' was not declared in this scope
   47 |         return max(a, b);
      |                    ^
segments.cpp:47:23: error: 'b' was not declared in this scope
   47 |         return max(a, b);
      |                       ^