QOJ.ac
QOJ
ID | Problem | Submitter | Result | Time | Memory | Language | File size | Submit time | Judge time |
---|---|---|---|---|---|---|---|---|---|
#838238 | #5069. Vacation | raywu | AC ✓ | 712ms | 64340kb | C++14 | 6.7kb | 2024-12-31 01:20:08 | 2024-12-31 01:20:08 |
Judging History
answer
#include <bits/stdc++.h>
#define _for(i, a, b) for (register int i = (a); i <= (b); i ++ )
#define ll long long
using namespace std;
namespace IO {
const int LIM = 1e6 + 5;
static char buf[LIM], * p1 = buf, * p2 = buf, obuf[LIM], * p3 = obuf, cc[20];
#define gc() (p1 == p2 && (p2 = (p1 = buf) + fread(buf, 1, LIM, stdin), p1 == p2) ? EOF : * p1 ++ )
#define pc(x) (p3 - obuf < LIM) ? ( * p3 ++ = x) : (fwrite(obuf, p3 - obuf, 1, stdout), p3 = obuf, * p3 ++ = x)
inline int rd() {
int val = 0, sgn = 1; char ch = gc();
while (! isdigit(ch)) { if (ch == '-') sgn = - 1; ch = gc(); }
while (isdigit(ch)) val = (val << 3) + (val << 1) + (ch ^ 48), ch = gc(); return (val * sgn);
} template <typename item>
inline void wt(item x, char c) {
if (! x) pc('0'); int len = 0;
if (x < 0) x = - x, pc('-');
while (x) cc[len ++ ] = x % 10 | '0', x /= 10;
while (len -- ) pc(cc[len]); pc(c);
}
} using namespace IO;
const int N = 2e6 + 5; const ll INF = (ll)1e18 + 5;
int n, q, c, m, L[N], R[N], bel[N], rt[N]; ll a[N], s[N];
inline void chkmax(ll & x, ll y) { if (x < y) x = y; }
struct Node_1 { ll pre, suf, sum, res; };
inline Node_1 operator + (Node_1 u, Node_1 v) { return (Node_1){max(u.pre, u.sum + v.pre), max(v.suf, v.sum + u.suf), u.sum + v.sum, max(u.suf + v.pre, max(u.res, v.res))}; }
struct Segment_Tree_1 {
#define lc (p << 1)
#define rc (p << 1 | 1)
#define mid ((l + r) >> 1)
Node_1 val[N << 2];
inline void push_up(int p) { val[p] = val[lc] + val[rc]; }
void build(int p, int l, int r) { if (l == r) return val[p] = (Node_1){a[l], a[l], a[l], a[l]}, void(); build(lc, l, mid), build(rc, mid + 1, r), push_up(p); }
void update(int p, int l, int r, int x, ll k) { if (l == r) return val[p] = (Node_1){k, k, k, k}, void(); (x <= mid ? update(lc, l, mid, x, k) : update(rc, mid + 1, r, x, k)), push_up(p); }
Node_1 query(int p, int l, int r, int L, int R) {
if (L > R) return (Node_1){ - INF, - INF, - INF, - INF};
if (L <= l && r <= R) return val[p];
if (R <= mid) return query(lc, l, mid, L, R);
if (L > mid) return query(rc, mid + 1, r, L, R); return query(lc, l, mid, L, R) + query(rc, mid + 1, r, L, R);
}
#undef lc
#undef rc
#undef mid
} SGT_1;
struct Segment_Tree_2 {
#define lc (p << 1)
#define rc (p << 1 | 1)
#define mid ((l + r) >> 1)
ll val[N << 2];
inline void push_up(int p) { val[p] = max(val[lc], val[rc]); }
void build(int p, int l, int r) { if (l ^ r) build(lc, l, mid), build(rc, mid + 1, r); }
void update(int p, int l, int r, int x, ll k) { if (l == r) return val[p] = k, void(); (x <= mid ? update(lc, l, mid, x, k) : update(rc, mid + 1, r, x, k)), push_up(p); }
ll query(int p, int l, int r, int L, int R) {
if (L > R) return - INF;
if (L <= l && r <= R) return val[p];
if (R <= mid) return query(lc, l, mid, L, R);
if (L > mid) return query(rc, mid + 1, r, L, R); return max(query(lc, l, mid, L, R), query(rc, mid + 1, r, L, R));
}
#undef lc
#undef rc
#undef mid
} SGT_2[2];
struct Node_2 { ll f, g, val; }; // f - suffix, g - preffix
inline Node_2 operator + (Node_2 u, Node_2 v) { return (Node_2){max(u.f, v.f), max(u.g, v.g), max(max(u.val, v.val), u.g + v.f)}; }
struct Segment_Tree_3 {
#define lc tr[p].ls
#define rc tr[p].rs
#define mid ((l + r) >> 1)
int cnt = 0; Node_2 val[N << 2];
struct Tree { int ls, rs; ll tag_f, tag_g;; } tr[N << 2];
inline void push_up(int p) { val[p] = val[lc] + val[rc]; }
inline void push_tag_f(int p, ll k) { if (val[p].val ^ ( - INF)) val[p].val += k; tr[p].tag_f += k, val[p].f += k; }
inline void push_tag_g(int p, ll k) { if (val[p].val ^ ( - INF)) val[p].val += k; tr[p].tag_g += k, val[p].g += k; }
inline void push_down(int p) { if (tr[p].tag_f || tr[p].tag_g) push_tag_f(lc, tr[p].tag_f), push_tag_f(rc, tr[p].tag_f), push_tag_g(lc, tr[p].tag_g), push_tag_g(rc, tr[p].tag_g), tr[p].tag_f = tr[p].tag_g = 0; }
void build(int & p, int l, int r) {
if ( ! p) p = ++ cnt;
if (l == r) return val[p] = (Node_2){s[R[bel[l]]] - s[l - 1], s[l + c] - s[L[bel[l] + 1] - 1], - INF}, void(); build(lc, l, mid), build(rc, mid + 1, r), push_up(p);
}
void update_f(int p, int l, int r, int L, int R, ll k) {
if (L > R) return ;
if (L <= l && r <= R) return push_tag_f(p, k); push_down(p);
if (L <= mid) update_f(lc, l, mid, L, R, k);
if (R > mid) update_f(rc, mid + 1, r, L, R, k); push_up(p);
}
void update_g(int p, int l, int r, int L, int R, ll k) {
if (L > R) return ;
if (L <= l && r <= R) return push_tag_g(p, k); push_down(p);
if (L <= mid) update_g(lc, l, mid, L, R, k);
if (R > mid) update_g(rc, mid + 1, r, L, R, k); push_up(p);
}
Node_2 query(int p, int l, int r, int L, int R) {
if (L > R) return (Node_2){ - INF, - INF, - INF};
if (L <= l && r <= R) return val[p]; push_down(p);
if (R <= mid) return query(lc, l, mid, L, R);
if (L > mid) return query(rc, mid + 1, r, L, R); return query(lc, l, mid, L, R) + query(rc, mid + 1, r, L, R);
}
#undef lc
#undef rc
#undef mid
} SGT_3;
inline void update(int x, ll y) {
int X = bel[x]; SGT_1.update(1, 1, n, x, y), SGT_3.update_f(rt[X], L[X], R[X], L[X], x, y - a[x]), SGT_2[0].update(1, 1, m, X, SGT_1.query(1, 1, n, L[X], R[X]).res);
if (X > 1) SGT_3.update_g(rt[X - 1], L[X - 1], R[X - 1], x - c, R[X - 1], y - a[x]), SGT_2[1].update(1, 1, m - 1, X - 1, SGT_3.val[rt[X - 1]].val);
if (X < m) SGT_2[1].update(1, 1, m - 1, X, SGT_3.val[rt[X]].val); a[x] = y;
}
inline ll query(int l, int r) {
if (r - l + 1 <= c) return SGT_1.query(1, 1, n, l, r).res; int bl = bel[l], br = bel[r];
ll ans = - INF; chkmax(ans, SGT_1.query(1, 1, n, l, l + c - 1).res), chkmax(ans, SGT_1.query(1, 1, n, r - c + 1, r).res), chkmax(ans, SGT_3.query(rt[br - 1], L[br - 1], R[br - 1], l, r - c).val);
if (bl + 1 <= br - 1) chkmax(ans, SGT_2[0].query(1, 1, m, bl + 1, br - 1));
if (bl + 1 <= br - 2) chkmax(ans, SGT_2[1].query(1, 1, m - 1, bl + 1, br - 2));
if ((bl + 1) ^ br) chkmax(ans, SGT_3.query(rt[bl], L[bl], R[bl], l, R[bl]).val); return ans;
}
int main() {
ios :: sync_with_stdio(false), cin.tie(0), cout.tie(0), cout.tie(0);
n = rd(), q = rd(), c = rd(), m = (int)ceil(n * 1.0 / c); int op, l, r, x; ll y;
_for (i, 1, n) a[i] = rd(); n = m * c;
_for (i, 1, n) s[i] = s[i - 1] + a[i], bel[i] = (i - 1) / c + 1;
_for (i, 1, m) L[i] = (i - 1) * c + 1, R[i] = i * c; SGT_1.build(1, 1, n);
_for (i, 1, m - 1) SGT_3.build(rt[i], L[i], R[i]);
_for (i, 1, m) SGT_2[0].update(1, 1, m, i, SGT_1.query(1, 1, n, L[i], R[i]).res);
_for (i, 1, m - 1) SGT_2[1].update(1, 1, m - 1, i, SGT_3.val[rt[i]].val);
while (q -- ) {
op = rd();
if (op == 1) x = rd(), y = rd(), update(x, y);
else if (op == 2) l = rd(), r = rd(), wt(max(0ll, query(l, r)), '\n');
}
return fwrite(obuf, p3 - obuf, 1, stdout), 0;
}
Details
Tip: Click on the bar to expand more detailed information
Test #1:
score: 100
Accepted
time: 3ms
memory: 20000kb
input:
5 6 3 0 -5 -3 8 -3 2 3 5 1 2 5 2 1 5 1 4 -3 2 3 5 2 1 5
output:
8 10 0 5
result:
ok 4 number(s): "8 10 0 5"
Test #2:
score: 0
Accepted
time: 453ms
memory: 64340kb
input:
200000 500000 1 387060158 961744470 37167782 737122872 -532977662 1604246 -30977399 871848791 444997246 454204578 -813187501 -660394286 448014171 -835115276 -631880452 887715308 258530352 805589560 -414653327 -156732249 -335096199 -80266237 367896009 738406627 -903652056 446120866 415658444 -1347916...
output:
999902477 999981999 999343404 999847372 999957587 998160312 999981999 999981999 999981999 999980061 999981999 999981999 999981999 999876122 999981999 999996602 999981999 999981999 999981999 999723649 999981999 999957587 999896087 999981999 999981999 999981999 999981999 999981999 999957587 999981999 ...
result:
ok 250051 numbers
Test #3:
score: 0
Accepted
time: 505ms
memory: 63160kb
input:
200000 500000 5 802774074 383481934 -295470374 285359286 751657057 197444479 626916547 -828168464 288373833 -493446966 -208422769 956745384 919286225 959643271 -176531848 -380256966 357111771 -50890039 -637284768 -337010918 259019684 752475630 -259898780 98620995 -704832505 -532710796 -971600790 -84...
output:
4544135313 4544135313 4443416295 3390067591 4544135313 4544135313 4322308420 4386413596 4386413596 4165697630 4322308420 4287938127 4443416295 4544135313 4386413596 4165697630 4386413596 4386413596 4386413596 4323325838 4443416295 4386413596 4385851999 4544135313 4443416295 4443416295 4323325838 432...
result:
ok 249998 numbers
Test #4:
score: 0
Accepted
time: 519ms
memory: 63488kb
input:
200000 500000 10 294669347 -694582751 -596596961 -126098203 564639690 -654836388 -393227122 -835904658 699214733 147549986 -60745155 364274902 6365735 182107449 544381751 8255910 -581710335 -254751705 -547803021 113792037 -526424167 -948294769 -456727013 -172857504 627985189 -660230969 -233539222 -3...
output:
6382761194 6975829216 5771846079 7795537121 6975829216 7251135307 7795537121 7795537121 7795537121 7251135307 6382761194 7251135307 7795537121 7795537121 7251135307 6166320975 7251135307 5845186875 6304374419 7795537121 6533205084 6975829216 7795537121 6051983693 7795537121 6533205084 6671392380 553...
result:
ok 249912 numbers
Test #5:
score: 0
Accepted
time: 647ms
memory: 63084kb
input:
200000 500000 50 682924062 -410171362 727046928 -248951706 447030590 -828489266 -766563199 -502548010 -959695696 -583569857 -305162329 -550851997 -462615752 -822803313 -640012170 267251148 340565257 -111341766 689672874 -515868601 -242875719 -162422332 49211711 277849676 -108078900 -304560362 -50058...
output:
15856525974 15423765469 15423765469 15728637453 15856525974 15728637453 15728637453 15060577990 15856525974 15856525974 15060577990 15856525974 15856525974 15856525974 15060577990 15728637453 15856525974 15856525974 15856525974 15856525974 15592293852 15856525974 15592293852 15856525974 15423765469 ...
result:
ok 249945 numbers
Test #6:
score: 0
Accepted
time: 629ms
memory: 63088kb
input:
200000 500000 100 -861625642 488714758 151701153 337144530 -318293290 -765334091 -210261967 -253541961 993816332 -736017816 52189861 -428475798 -281280689 875335671 889366119 -863352867 4083578 382040499 152212580 696548442 348806166 -403452187 -91390158 -86542614 -915521115 -615218473 374313280 -60...
output:
22356669163 16483275109 20675548507 20675548507 18341749229 16758974141 19886103941 22356669163 12776363397 19919404941 22356669163 22356669163 22356669163 20675548507 22356669163 22356669163 20675548507 22356669163 19886103941 20352085144 22356669163 22356669163 19064838381 19782436621 20675548507 ...
result:
ok 250001 numbers
Test #7:
score: 0
Accepted
time: 645ms
memory: 61648kb
input:
200000 500000 500 560111824 156076602 -300062433 -135130960 172514238 -107440145 332810571 -462042876 -248802506 163714210 -330670470 42796256 -486522143 -669315725 -916663241 992138762 904514188 -430525531 509990997 -414368382 886580739 968753025 -783053293 60399434 -189320070 -2477706 -334706343 4...
output:
51487237399 38429372430 32781696692 35966554114 51487237399 51487237399 49119655459 40039498632 49119655459 42076835781 51487237399 42076835781 40039498632 51487237399 40039498632 51487237399 43222631363 40936887546 38671383728 35611226388 42076835781 51487237399 51487237399 51487237399 35611226388 ...
result:
ok 249987 numbers
Test #8:
score: 0
Accepted
time: 712ms
memory: 60704kb
input:
200000 500000 1000 -274863070 -196927487 -173462836 -322148327 -974733923 872416187 81984586 243765318 392194447 16424530 -680051160 -870124234 197884950 51597873 -580027867 53316656 943742315 -289166281 665826659 505220474 -814189661 771924792 945468209 -606782872 -316840243 735583862 163401810 -98...
output:
68585884487 68585884487 68585884487 48732425297 68585884487 68585884487 34196859335 68585884487 44187544054 68585884487 59171503971 45112394103 48732425297 68585884487 68585884487 62264064415 68585884487 68585884487 68585884487 68585884487 68585884487 68585884487 62264064415 68585884487 44187544054 ...
result:
ok 249847 numbers
Test #9:
score: 0
Accepted
time: 648ms
memory: 60396kb
input:
200000 500000 5000 -233541473 -821406097 -834373426 -682847219 -558452214 794047404 658431025 584854890 -43958103 -471082436 456699444 660894280 -563936020 867203954 -26065334 680624954 844062461 -808600596 -206923771 788768922 266650071 -722136485 -308857317 414063248 333797658 468533943 -346326422...
output:
111528324186 111528324186 122473166396 88429113651 121592699866 90259744634 22840599473 111528324186 111528324186 121592699866 111528324186 111528324186 121592699866 88429113651 39504491251 121848200792 52521769508 97463661530 111528324186 35002189953 121848200792 98152563998 60222302625 29889397997...
result:
ok 249934 numbers
Test #10:
score: 0
Accepted
time: 695ms
memory: 61080kb
input:
200000 500000 10000 665344648 603248129 584747190 794918694 -495297038 -649651364 907437075 243399623 -196406062 424326840 284108349 842229343 891113172 396582242 895208153 639110569 -419465483 653939112 -456449644 -619549194 320587509 -619648562 -968216902 -393378967 -271827747 -656563637 194138895...
output:
56259543721 45446857386 127693546205 139657304562 139734032583 145066327195 151709822656 151709822656 151709822656 59196591326 151709822656 151709822656 151709822656 93441101388 145765337767 151709822656 151709822656 139657304562 139657304562 76339935235 82918361465 145765337767 152180432737 1521804...
result:
ok 249995 numbers
Test #11:
score: 0
Accepted
time: 537ms
memory: 57828kb
input:
200000 500000 50000 575796283 151484543 -720552679 -957363572 -132370386 -401546120 455846368 -409284627 408358670 41466509 998470195 393898097 -115481139 -871390033 993789573 -165491528 819845991 -936404970 189543742 213192673 -602174573 740565806 -821274853 332822078 340913021 634416742 950042524 ...
output:
34822696696 304044933300 68367040267 189494218463 334878403626 267659551435 24069522488 207246743747 266472736311 256136296058 318863343332 266472736311 318863343332 333342852149 333342852149 333342852149 333342852149 333342852149 244890005888 333894397388 14926116799 327180309259 169083865298 30229...
result:
ok 249979 numbers
Test #12:
score: 0
Accepted
time: 392ms
memory: 53204kb
input:
200000 500000 100000 569636990 278084140 -907570046 -104611731 552518652 -409282313 -595255647 231712326 556036284 -307914181 -157540087 -678605019 67375374 -777844451 54967467 -421230696 909327738 924463398 814165304 217454981 -504035512 469087307 268453049 448391697 -626058118 -867475106 -71503492...
output:
183803743045 84753846309 183803743045 184110002817 105439165831 67546271314 169297374450 99805942710 169297374450 182981361171 104276266099 264432291020 151095250825 264578163447 113845850587 185483046361 197245535689 185483046361 171141245411 163740444589 46081034455 99805942710 151095250825 171141...
result:
ok 249890 numbers
Test #13:
score: 0
Accepted
time: 263ms
memory: 37268kb
input:
200000 500000 200000 -797962146 -508688404 710511327 -513510680 728213176 552511953 -936241431 488159917 -444295562 -536695906 -505756916 130939739 614047261 -713095641 846308813 714302364 -50331832 62015532 -201658784 708890384 -759229325 -444174649 718951299 -388948828 877697837 -860392893 5422631...
output:
13912697561 53056934566 408059533397 26752612529 231772401996 408919427178 79448528167 268531947957 134457596821 132829174449 109465830672 94113395976 408210605035 408210605035 408210605035 79283848538 409284836395 75674809566 231092415035 90163884680 99205202539 269241228577 106739591025 1438823581...
result:
ok 249963 numbers