QOJ.ac
QOJ
ID | 题目 | 提交者 | 结果 | 用时 | 内存 | 语言 | 文件大小 | 提交时间 | 测评时间 |
---|---|---|---|---|---|---|---|---|---|
#383294 | #5069. Vacation | hhoppitree | AC ✓ | 223ms | 114892kb | C++14 | 9.9kb | 2024-04-09 09:36:21 | 2024-04-09 09:36:21 |
Judging History
answer
#include <bits/stdc++.h>
using namespace std;
const int N = 1e6 + 5;
long long States[N * 20], *nowState = States;
inline long long* myMalloc(int sz, int flg = 0)
{
long long *sta = nowState;
nowState += sz;
if (flg) {
fill(sta, nowState, (long long)-1e18);
}
return sta;
}
char I[40000050], *J = I, O[8000050], *o = O;
inline int read()
{
unsigned int x = 0;
bool zf = 0;
while ((*J < 48 || 57 < *J) && (*J) != '-') ++J;
((*J++ == '-') ? (zf = 1) : x = *(J - 1) ^ 48);
while (47 < *J && *J < 58) x = (x << 1) + (x << 3) + (*J++ ^ 48);
return (zf ? -(int)x : x);
}
inline void print(unsigned long long x)
{
static unsigned long long S[16], T = 0, y;
do y = x / 10, S[T++] = x - y * 10; while(x = y);
while (T) *o++ = S[--T] ^ 48;
}
int n, m, C;
long long a[N];
namespace SEG1
{
typedef long long LL;
typedef tuple<LL, LL, LL, LL> dt;
int sz;
dt z[1 << 22];
inline dt operator + (dt x, dt y)
{
auto [a, b, c, d] = x;
auto [e, f, g, h] = y;
return {a + e, max({b, f, d + g}), max(c, a + g), max(h, e + d)};
}
inline void build()
{
sz = 1;
while (sz <= n + 1) {
sz <<= 1;
}
for (int i = 1; i <= n; ++i) {
z[i + sz] = {a[i], max(a[i], 0ll), max(a[i], 0ll), max(a[i], 0ll)};
}
for (int i = (n + sz) >> 1; i; --i) {
z[i] = z[i << 1] + z[i << 1 | 1];
}
return;
}
inline void modify(int x)
{
z[x + sz] = {a[x], max(a[x], 0ll), max(a[x], 0ll), max(a[x], 0ll)};
x += sz;
while (x >>= 1) {
z[x] = z[x << 1] + z[x << 1 | 1];
}
return;
}
inline long long query(int L, int R)
{
dt rL = {0, 0, 0, 0}, rR = {0, 0, 0, 0};
for (L += sz - 1, R += sz + 1; L ^ R ^ 1; L >>= 1, R >>= 1) {
(!(L & 1)) && (rL = rL + z[L ^ 1], 0);
(R & 1) && (rR = z[R ^ 1] + rR, 0);
}
auto [A, B, C, D] = rL + rR;
return B;
}
inline long long cb(dt z)
{
auto &[A, B, C, D] = z;
return A;
}
inline long long querySum(int L, int R)
{
if (L > R) {
return 0ll;
}
long long S = 0;
for (L += sz - 1, R += sz + 1; L ^ R ^ 1; L >>= 1, R >>= 1) {
(!(L & 1)) && (S += cb(z[L ^ 1]), 0);
(R & 1) && (S += cb(z[R ^ 1]), 0);
}
return S;
}
}
int bl;
long long glo1[N], glo2[N];
namespace SEG2
{
int n, sz;
long long mx[1 << 22];
inline void build()
{
n = bl - 2, sz = 1;
while (sz <= n + 1) {
sz <<= 1;
}
for (int i = 1; i <= n; ++i) {
mx[i + sz] = max(glo1[i], glo2[i]);
}
for (int i = (n + sz) >> 1; i; --i) {
mx[i] = max(mx[i << 1], mx[i << 1 | 1]);
}
return;
}
inline void modify(int x)
{
mx[x + sz] = max(glo1[x], glo2[x]);
x += sz;
while (x >>= 1) {
mx[x] = max(mx[x << 1], mx[x << 1 | 1]);
}
return;
}
inline long long query(int L, int R)
{
long long res = 0;
for (L += sz - 1, R += sz + 1; L ^ R ^ 1; L >>= 1, R >>= 1) {
(!(L & 1)) && (res = max(res, mx[L ^ 1]));
((R & 1)) && (res = max(res, mx[R ^ 1]));
}
return res;
}
}
long long Sa[N], Sb[N];
inline tuple<long long, long long, long long, long long, long long> operator + (tuple<long long, long long, long long, long long, long long> x, tuple<long long, long long, long long, long long, long long> y);
struct DS
{
int len, sz;
typedef long long LL;
LL *SuA, *SuB, *MxA, *MxB, *S;
friend inline tuple<LL, LL, LL, LL, LL> operator + (tuple<LL, LL, LL, LL, LL> x, tuple<LL, LL, LL, LL, LL> y)
{
auto &[A, B, C, D, E] = x;
auto &[F, G, H, I, J] = y;
return {A + F, B + G, max(H, C + F), max(D, I + B), max({E + F, J + B, H + D})};
}
inline void Build()
{
int t = len, z = 1;
while (z <= t + 1) {
z <<= 1;
}
sz = z;
SuA = myMalloc(len + sz + 1);
SuB = myMalloc(len + sz + 1);
MxA = myMalloc(len + sz + 1, 1);
MxB = myMalloc(len + sz + 1, 1);
S = myMalloc(len + sz + 1, 1);
for (int i = 1; i <= len; ++i) {
SuA[i + sz] = MxA[i + sz] = Sa[i];
SuB[i + sz] = MxB[i + sz] = Sb[i];
S[i + sz] = -1e18;
}
for (int k = (len + z) >> 1; k; --k) {
SuA[k] = SuA[k << 1] + SuA[k << 1 | 1];
SuB[k] = SuB[k << 1] + SuB[k << 1 | 1];
MxA[k] = max(MxA[k << 1 | 1], SuA[k << 1 | 1] + MxA[k << 1]);
MxB[k] = max(MxB[k << 1], SuB[k << 1] + MxB[k << 1 | 1]);
S[k] = max({S[k << 1] + SuA[k << 1 | 1], S[k << 1 | 1] + SuB[k << 1], MxA[k << 1 | 1] + MxB[k << 1]});
}
return;
}
inline long long query(int L, int R)
{
tuple<LL, LL, LL, LL, LL> tA = {0, 0, -1e18, -1e18, -1e18}, tB = {0, 0, -1e18, -1e18, -1e18};
for (L += sz - 1, R += sz + 1; L ^ R ^ 1; L >>= 1, R >>= 1) {
(!(L & 1)) && (tA = tA + tuple<LL, LL, LL, LL, LL>{SuA[L ^ 1], SuB[L ^ 1], MxA[L ^ 1], MxB[L ^ 1], S[L ^ 1]}, 0);
((R & 1)) && (tB = tuple<LL, LL, LL, LL, LL>{SuA[R ^ 1], SuB[R ^ 1], MxA[R ^ 1], MxB[R ^ 1], S[R ^ 1]} + tB, 0);
}
auto [A, B, C, D, E] = tA + tB;
return E;
}
inline void modifyA(int k, int y)
{
k += sz;
SuA[k] += y, MxA[k] += y;
while (k >>= 1) {
SuA[k] = SuA[k << 1] + SuA[k << 1 | 1];
MxA[k] = max(MxA[k << 1 | 1], SuA[k << 1 | 1] + MxA[k << 1]);
S[k] = max({S[k << 1] + SuA[k << 1 | 1], S[k << 1 | 1] + SuB[k << 1], MxA[k << 1 | 1] + MxB[k << 1]});
}
return;
}
inline void modifyB(int k, int y)
{
k += sz;
SuB[k] += y, MxB[k] += y;
while (k >>= 1) {
SuB[k] = SuB[k << 1] + SuB[k << 1 | 1];
MxB[k] = max(MxB[k << 1], SuB[k << 1] + MxB[k << 1 | 1]);
S[k] = max({S[k << 1] + SuA[k << 1 | 1], S[k << 1 | 1] + SuB[k << 1], MxA[k << 1 | 1] + MxB[k << 1]});
}
return;
}
inline void modify(int type, int x, int y)
{
if (!type) {
modifyA(x, y);
} else {
modifyB(x, y);
}
return;
}
} SEG3[N];
inline long long calc(int wh, int L = 0, int R = 0, long long V = 0)
{
if (!L) {
return SEG3[wh].S[1];
}
if (SEG1::query(L, R + C) <= V) {
return V;
}
L -= (wh - 1) * C, R -= (wh - 1) * C;
return SEG3[wh].query(L, R) + SEG1::querySum(wh * C + 1, wh * C + L - 1) + SEG1::querySum((wh - 1) * C + R + 1, wh * C);
}
signed main()
{
fread(I, 1, 40000038, stdin);
n = read(), m = read(), C = read();
bl = (n - 1) / C + 1;
for (int i = 1; i <= n; ++i) {
a[i] = read();
}
SEG1::build();
for (int i = 2; i <= bl - 1; ++i) {
long long s = 0, mx = 0;
for (int j = (i - 1) * C + 1; j <= i * C && j <= n; ++j) {
mx = max(mx, s = max(s, 0ll) + a[j]);
}
glo1[i] = mx;
}
for (int i = 1; i <= bl - 1; ++i) {
SEG3[i].len = min((i + 1) * C, n) - i * C;
for (int j = 1; j <= SEG3[i].len; ++j) {
Sa[j] = a[j + (i - 1) * C];
}
for (int j = 1; j <= SEG3[i].len; ++j) {
Sb[j] = a[j + i * C];
}
SEG3[i].Build();
}
for (int i = 2; i <= bl - 2; ++i) {
glo2[i] = calc(i);
}
SEG2::build();
while (m--) {
int opt = read(), L = read(), R = read();
if (opt == 1) {
if (a[L] == R) {
continue;
}
int D = R - a[L];
a[L] = R;
SEG1::modify(L);
int bel = (L - 1) / C + 1;
long long flg = max(glo1[bel], glo2[bel]);
if (bel >= 2 && bel <= bl - 1) {
glo1[bel] = SEG1::query((bel - 1) * C + 1, bel * C);
}
if (bel >= 2) {
SEG3[bel - 1].modify(1, L - (bel - 1) * C, D);
}
if (bel <= bl - 1) {
SEG3[bel].modify(0, L - (bel - 1) * C, D);
}
if (bel >= 3) {
long long tv = max(glo1[bel - 1], glo2[bel - 1]);
glo2[bel - 1] = calc(bel - 1);
if (max(glo1[bel - 1], glo2[bel - 1]) != tv && bel <= bl - 1) {
SEG2::modify(bel - 1);
}
}
if (bel >= 2 && bel <= bl - 2) {
glo2[bel] = calc(bel);
}
if (bel >= 2 && bel <= bl - 2 && flg != max(glo1[bel], glo2[bel])) {
SEG2::modify(bel);
}
} else {
if (R - L + 1 <= C) {
print(SEG1::query(L, R));
*o++ = '\n';
continue;
}
int bel = (L - 1) / C + 1, ber = (R - 1) / C + 1;
long long res = (bel + 2 >= ber ? 0ll : SEG2::query(bel + 1, ber - 2));
if (bel + 1 != ber) {
res = max(res, glo1[ber - 1]);
}
res = max({res, SEG1::query(L, L + C - 1), SEG1::query(R - C + 1, R)});
if (ber == bel + 1) {
res = max(res, calc(bel, L, R - C, res));
} else {
res = max({res, calc(bel, L, bel * C, res), calc(ber - 1, (ber - 2) * C + 1, R - C, res)});
}
print(res);
*o++ = '\n';
}
}
fwrite(O, 1, o - O, stdout);
return 0;
}
详细
Test #1:
score: 100
Accepted
time: 0ms
memory: 19964kb
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: 156ms
memory: 114892kb
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: 144ms
memory: 80496kb
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: 146ms
memory: 76272kb
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: 175ms
memory: 75512kb
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: 176ms
memory: 69336kb
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: 202ms
memory: 71316kb
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: 221ms
memory: 69136kb
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: 215ms
memory: 73364kb
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: 223ms
memory: 73288kb
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: 183ms
memory: 65092kb
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: 129ms
memory: 62992kb
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: 73ms
memory: 42564kb
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