QOJ.ac

QOJ

ID题目提交者结果用时内存语言文件大小提交时间测评时间
#838238#5069. VacationraywuAC ✓712ms64340kbC++146.7kb2024-12-31 01:20:082024-12-31 01:20:08

Judging History

你现在查看的是最新测评结果

  • [2024-12-31 01:20:08]
  • 评测
  • 测评结果:AC
  • 用时:712ms
  • 内存:64340kb
  • [2024-12-31 01:20:08]
  • 提交

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;
}

詳細信息

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