CSES - Aalto Competitive Programming 2024 - wk4 - Wed - Results
Submission details
Task:Box Stack II
Sender:aalto2024d_002
Submission time:2024-09-25 18:03:03 +0300
Language:C++ (C++17)
Status:READY
Result:
Test results
testverdicttime
#1ACCEPTED0.00 sdetails
#2ACCEPTED0.00 sdetails
#3ACCEPTED0.00 sdetails
#4ACCEPTED0.00 sdetails
#5ACCEPTED0.00 sdetails
#6ACCEPTED0.00 sdetails
#7ACCEPTED0.00 sdetails
#8ACCEPTED0.00 sdetails
#9ACCEPTED0.00 sdetails
#10ACCEPTED0.00 sdetails
#11ACCEPTED0.00 sdetails
#12ACCEPTED0.00 sdetails
#13ACCEPTED0.00 sdetails
#14ACCEPTED0.00 sdetails
#15ACCEPTED0.00 sdetails
#16ACCEPTED0.00 sdetails
#17ACCEPTED0.00 sdetails
#18ACCEPTED0.00 sdetails
#19ACCEPTED0.00 sdetails
#20ACCEPTED0.00 sdetails
#21ACCEPTED0.00 sdetails
#22ACCEPTED0.00 sdetails
#23ACCEPTED0.00 sdetails
#24ACCEPTED0.00 sdetails
#25ACCEPTED0.00 sdetails
#26ACCEPTED0.00 sdetails
#27ACCEPTED0.00 sdetails
#28ACCEPTED0.00 sdetails
#29ACCEPTED0.00 sdetails
#30ACCEPTED0.00 sdetails
#31ACCEPTED0.00 sdetails
#320.00 sdetails
#330.00 sdetails
#340.00 sdetails
#350.00 sdetails
#360.00 sdetails
#370.00 sdetails
#380.00 sdetails
#390.00 sdetails
#400.00 sdetails
#410.00 sdetails
#420.00 sdetails
#430.00 sdetails
#440.00 sdetails
#450.00 sdetails
#460.00 sdetails
#470.00 sdetails
#480.00 sdetails
#490.00 sdetails
#500.00 sdetails
#510.00 sdetails
#520.01 sdetails
#530.01 sdetails
#540.01 sdetails
#550.01 sdetails
#560.01 sdetails
#570.01 sdetails
#580.01 sdetails
#590.01 sdetails
#600.01 sdetails
#610.01 sdetails
#620.34 sdetails
#630.34 sdetails
#640.34 sdetails
#650.35 sdetails
#660.34 sdetails
#670.34 sdetails
#680.34 sdetails
#690.34 sdetails
#700.34 sdetails
#710.34 sdetails
#720.35 sdetails
#730.27 sdetails

Code

#include <bits/stdc++.h>
using namespace std;
using ll = long long;

using st = int;
#define SE_OP(a, b) max(a, b)

const int N = 1<<18;

st S[N*2];

void init() {
  for (int i = 0; i < N*2; ++i) S[i] = 0;
}

void add(int i, st x) {
  i |= N;
  S[i] = x;
  for (i /= 2; i >= 1; i /= 2) {
    S[i] = SE_OP(S[i*2], S[i*2+1]);
  }
}

st get(int a, int b) {
  a |= N; b |= N;
  st s = 0;
  while (a <= b) {
    if (a % 2 == 1) {
      s = SE_OP(s, S[a]);
      ++a;
    } if (b % 2 == 0) {
      s = SE_OP(s, S[b]);
      --b;
    }
    a /= 2; b /= 2;
  }
  return s;
}

tuple<int,int,int,int> T[N];

int main() {
  int n;
  cin >> n;
  for (int i = 0; i < n; ++i) {
    int a,b,c;
    cin >> a >> b >> c;
    T[i] = {b,a,c,0};
  }
	sort(T,T+n);
	for (int i = 0; i < n; ++i) {
		auto [a,b,c,d] = T[i];
		T[i] = {b,a,c,i};
	}
	sort(T,T+n);
	ll ans = 0;
	for (int i = 0; i < n; ++i) {
		auto [a,b,c,j] = T[i];
		ll r = c + get(0,j);
		add(j,r);
		ans = max(ans,r);
	}
	cout << ans << '\n';
}

Test details

Test 1

Verdict: ACCEPTED

input
1
7 8 3

correct output
3

user output
3

Test 2

Verdict: ACCEPTED

input
2
6 5 4
1 1 1

correct output
5

user output
5

Test 3

Verdict: ACCEPTED

input
2
3 6 7
9 7 10

correct output
17

user output
17

Test 4

Verdict: ACCEPTED

input
2
5 1 3
8 5 9

correct output
12

user output
12

Test 5

Verdict: ACCEPTED

input
3
7 7 4
2 6 9
2 5 2

correct output
15

user output
15

Test 6

Verdict: ACCEPTED

input
3
8 2 9
9 6 8
7 7 3

correct output
17

user output
17

Test 7

Verdict: ACCEPTED

input
3
1 6 6
5 1 9
10 6 10

correct output
19

user output
19

Test 8

Verdict: ACCEPTED

input
4
1 2 1
7 8 3
3 4 8
6 6 3

correct output
15

user output
15

Test 9

Verdict: ACCEPTED

input
4
8 2 9
9 6 8
7 7 3
1 6 4

correct output
17

user output
17

Test 10

Verdict: ACCEPTED

input
4
1 2 3
5 2 10
6 2 5
7 3 6

correct output
24

user output
24

Test 11

Verdict: ACCEPTED

input
4
9 7 7
3 8 3
2 2 10
10 7 4

correct output
21

user output
21

Test 12

Verdict: ACCEPTED

input
5
6 6 8
9 7 9
6 9 5
7 7 4
...

correct output
30

user output
30

Test 13

Verdict: ACCEPTED

input
5
5 10 8
10 1 2
4 10 2
3 1 4
...

correct output
14

user output
14

Test 14

Verdict: ACCEPTED

input
5
5 2 1
10 6 10
5 5 5
4 4 2
...

correct output
17

user output
17

Test 15

Verdict: ACCEPTED

input
5
6 1 8
9 3 2
6 6 9
5 9 1
...

correct output
20

user output
20

Test 16

Verdict: ACCEPTED

input
5
10 10 6
2 10 9
8 7 7
6 3 2
...

correct output
15

user output
15

Test 17

Verdict: ACCEPTED

input
5
3 1 9
9 3 4
10 10 5
1 7 4
...

correct output
20

user output
20

Test 18

Verdict: ACCEPTED

input
5
9 10 4
3 9 1
1 4 2
10 6 1
...

correct output
11

user output
11

Test 19

Verdict: ACCEPTED

input
5
1 3 8
4 5 10
8 5 10
4 6 3
...

correct output
28

user output
28

Test 20

Verdict: ACCEPTED

input
5
9 1 10
3 9 4
6 9 3
5 1 7
...

correct output
17

user output
17

Test 21

Verdict: ACCEPTED

input
5
1 4 6
5 5 1
2 4 2
1 3 9
...

correct output
18

user output
18

Test 22

Verdict: ACCEPTED

input
10
6 6 8
9 7 9
6 9 5
7 7 4
...

correct output
41

user output
41

Test 23

Verdict: ACCEPTED

input
10
5 10 8
10 1 2
4 10 2
3 1 4
...

correct output
35

user output
35

Test 24

Verdict: ACCEPTED

input
10
5 2 1
10 6 10
5 5 5
4 4 2
...

correct output
33

user output
33

Test 25

Verdict: ACCEPTED

input
10
6 1 8
9 3 2
6 6 9
5 9 1
...

correct output
21

user output
21

Test 26

Verdict: ACCEPTED

input
10
10 10 6
2 10 9
8 7 7
6 3 2
...

correct output
36

user output
36

Test 27

Verdict: ACCEPTED

input
10
3 1 9
9 3 4
10 10 5
1 7 4
...

correct output
37

user output
37

Test 28

Verdict: ACCEPTED

input
10
9 10 4
3 9 1
1 4 2
10 6 1
...

correct output
25

user output
25

Test 29

Verdict: ACCEPTED

input
10
1 3 8
4 5 10
8 5 10
4 6 3
...

correct output
33

user output
33

Test 30

Verdict: ACCEPTED

input
10
9 1 10
3 9 4
6 9 3
5 1 7
...

correct output
28

user output
28

Test 31

Verdict: ACCEPTED

input
10
1 4 6
5 5 1
2 4 2
1 3 9
...

correct output
29

user output
29

Test 32

Verdict:

input
100
589284012 636562060 767928734
906523441 647212241 921212095
585063857 909729626 454895875
669546421 693523526 412726717
...

correct output
10998205207

user output
2121052055

Test 33

Verdict:

input
100
447773962 773442532 122816
137572579 324627123 157577940
253498609 99147813 425825313
199995380 416515986 371043004
...

correct output
8897447989

user output
2129409552

Test 34

Verdict:

input
100
468145963 198730372 27838076
590195590 467423861 520495379
451366491 344173378 354694313
165814381 219739800 750398099
...

correct output
9141888792

user output
2143167245

Test 35

Verdict:

input
100
591414747 75940263 760367935
901888417 312356591 130275571
548496961 611293382 958794496
469291685 962387379 20130523
...

correct output
10698400685

user output
2142255562

Test 36

Verdict:

input
100
967034924 587586158 185430194
918715995 767527830 653946995
749180621 641621091 232024335
151896000 241061404 6689688
...

correct output
12833486742

user output
2133227041

Test 37

Verdict:

input
100
238363353 59249204 934941692
892631472 221963002 390559518
986350949 524427523 96444602
656854970 425992688 822387303
...

correct output
11001071375

user output
2147288234

Test 38

Verdict:

input
100
958701283 356460601 224848374
881788059 68992860 44771412
397401947 115595477 638932295
106806913 568887059 653343572
...

correct output
8425454448

user output
2134542099

Test 39

Verdict:

input
100
81935404 244103474 837431431
342493822 470738321 776814822
489180570 330726191 578205540
283329158 538074003 93140055
...

correct output
10342518662

user output
2122701982

Test 40

Verdict:

input
100
937837681 11934038 257096283
933290530 405355767 570001955
876668629 249890139 453495728
12239373 657165788 462212374
...

correct output
8144852495

user output
2132633694

Test 41

Verdict:

input
100
11139168 391337048 538883744
535937150 532332526 8099343
143698367 339543270 152590624
14304401 234675590 941909102
...

correct output
9522402349

user output
2143592572

Test 42

Verdict:

input
200
589284012 636562060 767928734
906523441 647212241 921212095
585063857 909729626 454895875
669546421 693523526 412726717
...

correct output
15209742885

user output
2144312504

Test 43

Verdict:

input
200
447773962 773442532 122816
137572579 324627123 157577940
253498609 99147813 425825313
199995380 416515986 371043004
...

correct output
13615506574

user output
2140764114

Test 44

Verdict:

input
200
468145963 198730372 27838076
590195590 467423861 520495379
451366491 344173378 354694313
165814381 219739800 750398099
...

correct output
12798974974

user output
2146659577

Test 45

Verdict:

input
200
591414747 75940263 760367935
901888417 312356591 130275571
548496961 611293382 958794496
469291685 962387379 20130523
...

correct output
15137965961

user output
2137675552

Test 46

Verdict:

input
200
967034924 587586158 185430194
918715995 767527830 653946995
749180621 641621091 232024335
151896000 241061404 6689688
...

correct output
17343709538

user output
2144387638

Test 47

Verdict:

input
200
238363353 59249204 934941692
892631472 221963002 390559518
986350949 524427523 96444602
656854970 425992688 822387303
...

correct output
16484729704

user output
2147288234

Test 48

Verdict:

input
200
958701283 356460601 224848374
881788059 68992860 44771412
397401947 115595477 638932295
106806913 568887059 653343572
...

correct output
13668103642

user output
2141634613

Test 49

Verdict:

input
200
81935404 244103474 837431431
342493822 470738321 776814822
489180570 330726191 578205540
283329158 538074003 93140055
...

correct output
12761842389

user output
2139297980

Test 50

Verdict:

input
200
937837681 11934038 257096283
933290530 405355767 570001955
876668629 249890139 453495728
12239373 657165788 462212374
...

correct output
13061107314

user output
2136849796

Test 51

Verdict:

input
200
11139168 391337048 538883744
535937150 532332526 8099343
143698367 339543270 152590624
14304401 234675590 941909102
...

correct output
14114713109

user output
2145708302

Test 52

Verdict:

input
1000
589284012 636562060 767928734
906523441 647212241 921212095
585063857 909729626 454895875
669546421 693523526 412726717
...

correct output
33891762384

user output
2145912244

Test 53

Verdict:

input
1000
447773962 773442532 122816
137572579 324627123 157577940
253498609 99147813 425825313
199995380 416515986 371043004
...

correct output
33355847789

user output
2147181806

Test 54

Verdict:

input
1000
468145963 198730372 27838076
590195590 467423861 520495379
451366491 344173378 354694313
165814381 219739800 750398099
...

correct output
33709682513

user output
2147212029

Test 55

Verdict:

input
1000
591414747 75940263 760367935
901888417 312356591 130275571
548496961 611293382 958794496
469291685 962387379 20130523
...

correct output
34006550890

user output
2146843072

Test 56

Verdict:

input
1000
967034924 587586158 185430194
918715995 767527830 653946995
749180621 641621091 232024335
151896000 241061404 6689688
...

correct output
34976444698

user output
2146990967

Test 57

Verdict:

input
1000
238363353 59249204 934941692
892631472 221963002 390559518
986350949 524427523 96444602
656854970 425992688 822387303
...

correct output
34699884028

user output
2147257575

Test 58

Verdict:

input
1000
958701283 356460601 224848374
881788059 68992860 44771412
397401947 115595477 638932295
106806913 568887059 653343572
...

correct output
34046313943

user output
2146457352

Test 59

Verdict:

input
1000
81935404 244103474 837431431
342493822 470738321 776814822
489180570 330726191 578205540
283329158 538074003 93140055
...

correct output
33580356050

user output
2147218688

Test 60

Verdict:

input
1000
937837681 11934038 257096283
933290530 405355767 570001955
876668629 249890139 453495728
12239373 657165788 462212374
...

correct output
35744107623

user output
2147281748

Test 61

Verdict:

input
1000
11139168 391337048 538883744
535937150 532332526 8099343
143698367 339543270 152590624
14304401 234675590 941909102
...

correct output
35345712189

user output
2145558508

Test 62

Verdict:

input
200000
589284012 636562060 767928734
906523441 647212241 921212095
585063857 909729626 454895875
669546421 693523526 412726717
...

correct output
526570534463

user output
2147480398

Test 63

Verdict:

input
200000
447773962 773442532 122816
137572579 324627123 157577940
253498609 99147813 425825313
199995380 416515986 371043004
...

correct output
527468957174

user output
2147483187

Test 64

Verdict:

input
200000
468145963 198730372 27838076
590195590 467423861 520495379
451366491 344173378 354694313
165814381 219739800 750398099
...

correct output
530364449483

user output
2147481492

Test 65

Verdict:

input
200000
591414747 75940263 760367935
901888417 312356591 130275571
548496961 611293382 958794496
469291685 962387379 20130523
...

correct output
531529346089

user output
2147472168

Test 66

Verdict:

input
200000
967034924 587586158 185430194
918715995 767527830 653946995
749180621 641621091 232024335
151896000 241061404 6689688
...

correct output
532748830637

user output
2147481834

Test 67

Verdict:

input
200000
238363353 59249204 934941692
892631472 221963002 390559518
986350949 524427523 96444602
656854970 425992688 822387303
...

correct output
525080370284

user output
2147482524

Test 68

Verdict:

input
200000
958701283 356460601 224848374
881788059 68992860 44771412
397401947 115595477 638932295
106806913 568887059 653343572
...

correct output
529566966249

user output
2147468023

Test 69

Verdict:

input
200000
81935404 244103474 837431431
342493822 470738321 776814822
489180570 330726191 578205540
283329158 538074003 93140055
...

correct output
521546866708

user output
2147475622

Test 70

Verdict:

input
200000
937837681 11934038 257096283
933290530 405355767 570001955
876668629 249890139 453495728
12239373 657165788 462212374
...

correct output
531573800077

user output
2147483228

Test 71

Verdict:

input
200000
11139168 391337048 538883744
535937150 532332526 8099343
143698367 339543270 152590624
14304401 234675590 941909102
...

correct output
529286403784

user output
2147482494

Test 72

Verdict:

input
200000
1000000000 1000000000 10000000...

correct output
200000000000000

user output
2000000000

Test 73

Verdict:

input
200000
1000000000 1 1
1000000000 2 2
1000000000 3 3
1000000000 4 4
...

correct output
20000100000

user output
2147450880