This submission is migrated from previous version of oj.uz, which used different machine for grading. This submission may have different result if resubmitted.
/** I can do this all day **/
#pragma GCC optimize("Ofast")
#include <bits/stdc++.h>
using namespace std;
typedef long long ll;
typedef long double ld;
typedef pair < int, int > pii;
typedef pair < ll, ll > pll;
#define F first
#define S second
#define all(x) x.begin(), x.end()
#define SZ(x) (int)x.size()
#define Mp make_pair
#define endl "\n"
#define fast_io ios::sync_with_stdio(0);cin.tie(0);cout.tie(0);
#define file_io freopen("inupt.txt", "r+", stdin); freopen("output.txt", "w+", stdout);
const int N = 1e6 + 10;
const ll mod = 1e9 + 7;
const ll inf = 1e18;
const int LOG = 20;
ll pw(ll a, ll b, ll M, ll ret = 1) { if(a == 0) return 0; a %= M; while(b) { ret = (b & 1? ret * a % M : ret), a = a * a % M, b >>= 1; } return ret % M; }
ll ps[N], Ans[N];
int n, ptr, A[N], fen[N];
void add(int i)
{
for(i += 5; i < N; i += i & -i)
{
fen[i] ^= 1;
}
}
void add(int l, int r)
{
add(l);
add(r + 1);
}
int get(int i, int ret = 0)
{
for(i += 5; i; i -= i & -i) ret ^= fen[i];
return ret;
}
inline ll Sum(int l, int r)
{
if(l > r) return 0ll;
if(r < 0) return 0ll;
return ps[r] - (l > 1? ps[l - 2] : 0);
}
set < pair < ll, pii > > st;
set < pii > Left, Right;
void Del(int l, int r)
{
Left.erase(Mp(l, r));
Right.erase(Mp(r, l));
st.erase(Mp(-Sum(l, r) + Sum(l + 1, r - 1), Mp(l, r)));
}
int main()
{
scanf("%d", &n);
for(int i = 1; i <= n; i ++)
{
scanf("%d", &A[i]);
ps[i] = A[i] + (i > 1? ps[i - 2] : 0);
}
ps[n + 1] = ps[n - 1];
ps[n + 2] = ps[n];
for(int i = 1; i <= n; i ++)
{
st.insert(Mp(-A[i], Mp(i, i)));
Left.insert(Mp(i, i));
Right.insert(Mp(i, i));
}
ptr = 0;
while(SZ(st))
{
/*for(int i = 1; i <= n; i ++)
{
printf("%d ", get(i));
}
printf("\n");
for(auto x : Left)
{
printf("%d %d\n", x.F, x.S);
}
printf("\n");
*/
pair < ll, pii > Cu = *st.begin();
st.erase(st.begin());
int l = Cu.S.F, r = Cu.S.S;
Left.erase(Mp(l, r));
Right.erase(Mp(r, l));
///printf("now : %d %d %lld\n", l, r, -Cu.F);
if(l < 1 || r > n) continue;
if(get(l - 1) == 1 || get(r + 1) == 1) continue;
ptr ++;
Ans[ptr] = Ans[ptr - 1] + (-Cu.F);
add(l, r);
if(get(l - 2))
{
///printf("im here\n");
pii cu = *Right.lower_bound(Mp(l - 1, -1));
Del(cu.S, cu.F);
l = cu.S;
}
else
{
l --;
}
if(get(r + 2))
{
///printf("im not here\n");
pii cu = *Left.lower_bound(Mp(r + 1, -1));
Del(cu.F, cu.S);
r = cu.S;
}
else
{
r ++;
}
///printf("l = %d r = %d\n", l, r);
if(l >= 1 && r <= n)
{
if(Left.find(Mp(l, l)) != Left.end())
{
Del(l, l);
}
if(Right.find(Mp(r, r)) != Right.end())
{
Del(r, r);
}
st.insert(Mp(-Sum(l, r) + Sum(l + 1, r - 1), Mp(l, r)));
Right.insert(Mp(r, l));
Left.insert(Mp(l, r));
}
else
{
st.insert(Mp(inf, Mp(l, r)));
Right.insert(Mp(r, l));
Left.insert(Mp(l, r));
}
}
for(int i = 1; i <= (n + 1) >> 1; i ++)
{
printf("%lld\n", Ans[i]);
}
return 0;
}
/** test corner cases(n = 1?) watch for overflow or minus indices **/
Compilation message (stderr)
candies.cpp: In function 'int main()':
candies.cpp:72:10: warning: ignoring return value of 'int scanf(const char*, ...)' declared with attribute 'warn_unused_result' [-Wunused-result]
72 | scanf("%d", &n);
| ~~~~~^~~~~~~~~~
candies.cpp:75:14: warning: ignoring return value of 'int scanf(const char*, ...)' declared with attribute 'warn_unused_result' [-Wunused-result]
75 | scanf("%d", &A[i]);
| ~~~~~^~~~~~~~~~~~~
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |