QOJ.ac
QOJ
ID | 题目 | 提交者 | 结果 | 用时 | 内存 | 语言 | 文件大小 | 提交时间 | 测评时间 |
---|---|---|---|---|---|---|---|---|---|
#110898 | #5069. Vacation | LitDarkness | ML | 721ms | 109312kb | C++14 | 7.5kb | 2023-06-04 16:07:47 | 2023-06-04 16:07:49 |
Judging History
answer
#include <bits/stdc++.h>
#define For(i, a, b) for (int i = a; i <= b; ++i)
#define Rep(i, a, b) for (int i = a; i >= b; --i)
using namespace std;
namespace io {
template<typename T>inline void read(T &x) {
char ch, f = 0; x = 0;
while (!isdigit(ch = getchar())) f |= ch == '-';
while (isdigit(ch)) x = (x << 1) + (x << 3) + (ch ^ 48), ch = getchar();
x = f? -x: x;
}
char ch[40];
template<typename T>inline void write(T x) {
(x < 0) && (putchar('-'), x = -x);
x || putchar('0');
int i = 0;
while (x) ch[i++] = x % 10 ^ 48, x /= 10;
while (i) putchar(ch[--i]);
}
}
#define rd io::read
#define wt io::write
using i64 = long long;
const int maxN = 2e5 + 5;
int a[maxN], c, n, blo, m;
struct Node1 {
i64 sum, pre, suf, ans;
Node1 operator+ (const Node1 &a) const {
return {sum + a.sum, max(pre, sum + a.pre), max(a.suf, a.sum + suf), max({ans, a.ans, suf + a.pre})};
}
};
struct Seg1 {
vector<Node1> T;
int len, beg;
inline void init(int l) { len = l; T.resize(l << 2|1); }
void build(int k, int l, int r) {
if (l == r) {
T[k].sum = a[beg + l - 1];
T[k].ans = T[k].suf = T[k].pre = max(0, a[beg + l - 1]);
return;
}
int mid = l + r >> 1;
build(k << 1, l, mid);
build(k << 1|1, mid + 1, r);
T[k] = T[k << 1] + T[k << 1|1];
}
void update(int x, int v, int k, int l, int r) {
if (l == r) {
T[k].sum = v;
T[k].ans = T[k].suf = T[k].pre = max(0, v);
return;
}
int mid = l + r >> 1;
if (x <= mid) update(x, v, k << 1, l, mid);
else update(x, v, k << 1|1, mid + 1, r);
T[k] = T[k << 1] + T[k << 1|1];
}
Node1 query(int x, int y, int k, int l, int r) {
if (x <= l && r <= y) return T[k];
int mid = l + r >> 1;
if (x <= mid) {
if (y > mid) return query(x, y, k << 1, l, mid) + query(x, y, k << 1|1, mid + 1, r);
return query(x, y, k << 1, l, mid);
}
return query(x, y, k << 1|1, mid + 1, r);
}
};
int bel[maxN], R[maxN];
struct Node2 {
i64 sa, sb, pa, pb, ans;
Node2 operator+ (const Node2 &a) const {
return {sa + a.sa, sb + a.sb, max(pa, sa + a.pa), max(a.pb, a.sb + pb), max({ans + a.sb, a.ans + sa, pa + a.pb})};
}
};
struct Seg2 {
vector<Node2> T;
int len, beg;
inline void init(int l) { len = l; T.resize(l << 2|1); }
void build(int k, int l, int r) {
if (l == r) {
T[k].sa = a[min(beg + l - 1 + c, n + 1)];
T[k].sb = a[beg + l - 1];
T[k].pa = max(T[k].sa, 0ll);
T[k].pb = max(T[k].sb, 0ll);
T[k].ans = max(T[k].pa, T[k].pb);
return;
}
int mid = l + r >> 1;
build(k << 1, l, mid);
build(k << 1|1, mid + 1, r);
T[k] = T[k << 1] + T[k << 1|1];
}
i64 lv, rv;
Node2 query(int x, int y, int k, int l, int r) {
if (x > y) return T[0];
if (x <= l && r <= y) return T[k];
int mid = l + r >> 1;
if (x <= mid) {
if (y > mid) return query(x, y, k << 1, l, mid) + query(x, y, k << 1|1, mid + 1, r);
rv += T[k << 1|1].sb;
return query(x, y, k << 1, l, mid);
}
lv += T[k << 1].sa;
return query(x, y, k << 1|1, mid + 1, r);
}
i64 Squery(int x, int y, int op) {
lv = rv = 0; Node2 rr = query(x, y, 1, 1, len);
i64 v = rv + lv + rr.ans; i64 gl = lv, gr = rv;
if (op == 0) v = max(v, rr.pa + gl + query(y + 1, len, 1, 1, len).pb);
else v = max(v, rr.pb + gr + query(1, x - 1, 1, 1, len).pa);
return v;
}
void update(int x, int op, int v, int k, int l, int r) {
if (l == r) {
if (op == 0) {
T[k].sa = v; T[k].pa = max(T[k].sa, 0ll);
} else {
T[k].sb = v; T[k].pb = max(T[k].sb, 0ll);
}
T[k].ans = max(T[k].pa, T[k].pb);
return;
}
int mid = l + r >> 1;
if (x <= mid) update(x, op, v, k << 1, l, mid);
else update(x, op, v, k << 1|1, mid + 1, r);
T[k] = T[k << 1] + T[k << 1|1];
}
};
vector<Seg1> T1;
vector<Seg2> T2;
vector<i64> mx, sx;
int lf[maxN];
void bbuild(int k = 1, int l = 1, int r = blo - 1) {
if (l == r) {
lf[l] = k;
sx[k] = T2[l].T[1].ans;
return;
}
int mid = l + r >> 1;
bbuild(k << 1, l, mid);
bbuild(k << 1|1, mid + 1, r);
sx[k] = max(sx[k << 1], sx[k << 1|1]);
}
inline void uupdate(int x) {
sx[lf[x]] = T2[x].T[1].ans;
x = lf[x] >> 1;
while (x) {
sx[x] = max(sx[x << 1], sx[x << 1|1]); x >>= 1;
}
}
i64 qqu(int x, int y, int k = 1, int l = 1, int r = blo - 1) {
if (x <= l && r <= y) return sx[k];
int mid = l + r >> 1; i64 ans = 0;
if (x <= mid) ans = max(ans, qqu(x, y, k << 1, l, mid));
if (y > mid) ans = max(ans, qqu(x, y, k << 1|1, mid + 1, r));
return ans;
}
void build(int k = 1, int l = 1, int r = blo) {
if (l == r) {
if (l < blo) {
T1[l].init(c); T2[l].init(c);
T1[l].beg = T2[l].beg = (l - 1) * c + 1;
T2[l].build(1, 1, c);
} else {
T1[l].init(n - (l - 1) * c);
T1[l].beg = (l - 1) * c + 1;
}
T1[l].build(1, 1, T1[l].len);
mx[k] = T1[l].T[1].ans;
return;
}
int mid = l + r >> 1;
build(k << 1, l, mid);
build(k << 1|1, mid + 1, r);
mx[k] = max(mx[k << 1], mx[k << 1|1]);
}
void update(int x, int v, int k = 1, int l = 1, int r = blo) {
if (l == r) {
int rr = x - R[l - 1];
T1[l].update(rr, v, 1, 1, T1[l].len);
if (l > 1) {
T2[l - 1].update(rr, 0, v, 1, 1, T2[l - 1].len);
uupdate(l - 1);
}
if (l < bel[n]) {
T2[l].update(rr, 1, v, 1, 1, T2[l].len);
uupdate(l);
}
mx[k] = T1[l].T[1].ans;
return;
}
int mid = l + r >> 1;
if (bel[x] <= mid) update(x, v, k << 1, l, mid);
else update(x, v, k << 1|1, mid + 1, r);
mx[k] = max(mx[k << 1], mx[k << 1|1]);
}
i64 query(int x, int y, int k = 1, int l = 1, int r = blo) {
if (x <= l && r <= y) return mx[k];
int mid = l + r >> 1; i64 ans = 0;
if (x <= mid) ans = max(ans, query(x, y, k << 1, l, mid));
if (y > mid) ans = max(ans, query(x, y, k << 1|1, mid + 1, r));
return ans;
}
inline int gv(int x) { return x - R[bel[x] - 1]; }
int Tim = 0;
i64 ask(int x, int y) {
++Tim;
if (bel[x] == bel[y])
return T1[bel[x]].query(gv(x), gv(y), 1, 1, R[bel[x]] - R[bel[x] - 1]).ans;
if (y - x + 1 <= c) {
Node1 p = T1[bel[x]].query(gv(x), T1[bel[x]].len, 1, 1, T1[bel[x]].len) + T1[bel[y]].query(1, gv(y), 1, 1, T1[bel[y]].len);
return p.ans;
}
if (bel[y] == bel[x] + 1) {
Node1 p;
if (x > R[bel[x] - 1] + 1) p = T1[bel[x]].query(gv(x), T1[bel[x]].len, 1, 1, T1[bel[x]].len) + T1[bel[x + c - 1]].query(1, gv(x + c - 1), 1, 1, T1[bel[y]].len);
else p = T1[bel[x]].T[1];
i64 ans = max(p.ans, T1[bel[y]].query(1, gv(y), 1, 1, T1[bel[y]].len).ans);
return max(ans, T2[bel[x]].Squery(gv(x + c), gv(y), 0));
}
i64 ans = max({query(bel[x] + 1, bel[y] - 1), T1[bel[x]].query(gv(x), T1[bel[x]].len, 1, 1, T1[bel[x]].len).ans, T1[bel[y]].query(1, gv(y), 1, 1, T1[bel[y]].len).ans});
if (bel[y] - bel[x] > 2) ans = max(ans, qqu(bel[x] + 1, bel[y] - 2));
ans = max({ans, T2[bel[x]].Squery(gv(x), c, 1), T2[bel[y] - 1].Squery(1, gv(y), 0)});
return ans;
}
int main() {
rd(n); rd(m); rd(c);
blo = (n - 1) / c + 1;
For (i, 1, n) {
rd(a[i]);
bel[i] = (i - 1) / c + 1;
}
For (i, 1, blo)
R[i] = min(R[i - 1] + c, n);
T1.resize(blo + 1); T2.resize(blo + 1); mx.resize(blo << 2|1); sx.resize(blo << 2|1);
build(); bbuild();
int op, x, y;
For (i, 1, m) {
rd(op); rd(x); rd(y);
if (op == 1) {
update(x, y);
} else {
wt(ask(x, y)); putchar('\n');
}
}
return 0;
}
详细
Test #1:
score: 100
Accepted
time: 2ms
memory: 5476kb
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: 721ms
memory: 109312kb
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: 545ms
memory: 71032kb
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: 558ms
memory: 65840kb
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: 579ms
memory: 63168kb
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: 613ms
memory: 61816kb
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: 650ms
memory: 61848kb
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: 690ms
memory: 61524kb
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: 633ms
memory: 61876kb
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: 678ms
memory: 60532kb
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: 561ms
memory: 53696kb
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: 429ms
memory: 45260kb
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: -100
Memory Limit Exceeded
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...