QOJ.ac

QOJ

IDProblemSubmitterResultTimeMemoryLanguageFile sizeSubmit timeJudge time
#267792#7771. 不是这一道据数构结题zhoukangyang40 604ms93928kbC++111.7kb2023-11-27 18:36:332023-11-27 18:36:33

Judging History

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

  • [2023-11-27 18:36:33]
  • 评测
  • 测评结果:40
  • 用时:604ms
  • 内存:93928kb
  • [2023-11-27 18:36:33]
  • 提交

answer

#include<bits/stdc++.h>
#define L(i, j, k) for(int i = (j); i <= (k); ++i)
#define R(i, j, k) for(int i = (j); i >= (k); --i)
#define ll long long
#define vi vector <int>
#define sz(a) ((int) (a).size())
#define me(f, x) memset(f, x, sizeof(f))
#define uint unsigned int
#define ull unsigned long long 
#define i128 __int128
using namespace std; 
const int N = 1e6 + 7;
int n, q; 
int a[N];
int ql[N], qr[N];
vi vc[N];
template < int N > struct fenwt {
	using F = long long ;
	F a[N + 1];
	void add (int x, F w) {
		for (; x <= N; x += x & -x) a[x] += w;
	}
	F query (int x) {
		F ret = 0;
		for (; x; x -= x & -x) ret += a[x];
		return ret;
	}
	F get (int l, int r) {
		if(l > r) return 0;
		return query (r) - query (l - 1);
	}
} ;

fenwt < N > F;

int stk[N], cnt[N], tp;
int ans[N];
vector < pair < int, int > > adds[N];
int main() {
	ios :: sync_with_stdio(false);
	cin.tie(0); cout.tie(0);
	cin >> n >> q;
	L(i, 1, n) {
		cin >> a[i];
	}
	L(t, 1, q) {
		cin >> ql[t] >> qr[t];
		vc[ql[t]].emplace_back(t);
	}
	stk[0] = n + 1;
	R(p, n, 1) {
		while(tp && a[p] < a[stk[tp]]) {
			for(auto&u : adds[tp])
				F.add(u.first, -u.second);
			--tp;
		}
		if(tp && a[stk[tp]] == a[p]) {
			++cnt[tp];
		} else {
			stk[++tp] = p, cnt[tp] = 1, adds[tp].clear();
		}
		int cp = stk[tp - 1] - 1, c = 0;
		while(cp <= n && c < cnt[tp]) ++cp, c += a[cp] > a[p];
		--c;
		int vl = stk[tp - 1] - cnt[tp] + 1, vr = cp;
		F.add(vl, 1), F.add(vr, -1);
		adds[tp].emplace_back(vl, 1), adds[tp].emplace_back(vr, -1);
		for(auto&t : vc[p]) {
			ans[t] = F.query(qr[t]);
		}
	}
	
	L(i, 1, q) cout << qr[i] - ql[i] - ans[i] << '\n';
	return 0;
}

Details

Tip: Click on the bar to expand more detailed information

Test #1:

score: 5
Accepted
time: 3ms
memory: 67272kb

input:

100 100
57 39 73 88 98 3 54 10 63 31 96 22 94 53 99 66 7 90 29 27 91 37 74 4 64 43 86 100 12 58 78 97 75 87 36 51 40 20 48 92 26 72 89 85 46 13 55 80 6 47 41 17 30 25 60 35 93 28 69 16 83 23 1 34 56 45 18 21 38 11 68 71 8 2 84 76 15 33 44 81 77 82 70 24 67 95 61 9 32 49 50 65 19 59 5 42 14 62 52 79
...

output:

65
91
17
7
11
1
56
21
0
11
48
8
3
13
6
37
11
86
2
53
36
0
45
66
44
21
3
30
41
23
51
53
32
17
34
38
36
8
55
39
15
2
10
3
41
86
46
8
1
35
17
78
14
58
19
57
45
9
67
40
16
78
47
55
12
30
80
7
4
65
37
19
4
35
30
39
42
2
7
18
14
17
39
58
63
49
33
10
8
16
23
66
50
0
41
46
1
23
6
0

result:

ok 100 numbers

Test #2:

score: 0
Wrong Answer
time: 7ms
memory: 67620kb

input:

100 100
2 3 1 3 3 8 1 1 1 3 2 3 2 75 1 44 78 3 3 65 2 1 3 3 90 2 1 1 1 2 2 2 1 2 9 3 24 1 2 1 89 2 2 42 2 66 1 1 19 25 3 2 3 2 3 51 1 1 3 1 3 29 21 2 2 2 1 2 1 3 3 2 84 2 1 11 2 2 3 2 9 1 1 1 1 99 48 1 77 3 9 78 69 1 2 1 1 2 1 2
21 68
41 76
9 76
7 43
30 81
45 84
81 83
23 45
57 91
17 65
72 81
39 91
3...

output:

47
34
66
36
51
39
2
22
29
48
9
44
44
8
51
35
63
37
43
56
14
8
43
14
55
29
61
66
14
71
58
35
9
30
32
6
36
59
17
21
57
38
29
67
51
7
8
69
12
35
14
12
35
31
36
21
37
55
36
24
8
45
52
3
57
39
57
61
35
29
60
20
23
36
23
4
14
2
5
47
2
19
66
45
26
12
17
18
65
12
14
36
52
51
40
48
48
34
11
58

result:

wrong answer 1st numbers differ - expected: '35', found: '47'

Test #3:

score: 5
Accepted
time: 3ms
memory: 64880kb

input:

3000 3000
82 1139 2770 344 363 880 427 2001 207 2969 1309 2063 2349 1817 1869 2724 2380 1887 1377 1422 1732 449 2105 1706 1155 2417 963 308 1996 2788 737 1963 1973 1163 2899 2438 760 1995 1435 1750 1947 2863 1606 1078 493 2922 1478 607 1871 2191 2978 2587 1699 332 1581 2048 68 350 2220 1306 1633 187...

output:

1464
908
1099
255
2577
10
1176
329
1715
2227
627
47
1353
1452
638
2746
1024
833
637
605
989
1107
1132
1186
152
2260
978
992
640
1104
685
2319
1892
162
1156
1113
1682
783
732
2043
477
334
983
889
2090
5
1260
983
615
1049
1375
1505
1820
1158
1168
599
657
295
23
170
2604
1663
1979
1664
1040
1133
156
48...

result:

ok 3000 numbers

Test #4:

score: 5
Accepted
time: 4ms
memory: 67320kb

input:

3000 3000
2120 271 658 684 1092 795 2522 2924 2204 382 709 1351 2977 1639 1190 2472 458 1337 1034 566 2644 664 1224 1410 1820 625 2203 2045 1979 2297 2926 1238 2014 1492 1372 2594 1324 1854 1968 1074 919 2345 1544 1880 626 2505 1742 1427 2892 99 447 1732 2273 2490 1166 2419 2717 1248 2493 1048 2291 ...

output:

1079
884
1832
57
331
105
2422
580
1210
1590
478
1119
2742
1547
1248
58
1400
1046
827
270
459
866
250
1301
1822
280
223
1048
2447
1175
2463
422
803
78
367
846
874
1006
422
991
723
449
343
2532
382
1163
2692
256
25
213
1699
805
43
1079
336
2
3
117
1651
1874
690
741
71
407
2427
784
469
1290
2059
754
10...

result:

ok 3000 numbers

Test #5:

score: 5
Accepted
time: 10ms
memory: 67356kb

input:

3000 3000
2637 1681 2145 1131 33 618 2714 914 2587 2182 1823 1044 1320 2020 568 2 411 902 523 2075 910 459 124 669 1546 2593 1314 312 2736 1408 1578 28 291 1017 421 798 2202 978 597 2246 1349 1486 2756 2464 1912 636 1130 201 648 882 2737 2066 2007 1758 91 2923 49 1288 2254 776 2814 1315 1665 2306 25...

output:

708
479
1013
1843
195
1485
1284
2305
87
1741
2238
306
258
854
1435
2489
1697
871
1639
336
1071
734
374
27
859
1513
1477
236
372
1481
92
779
176
168
959
1533
814
1219
139
1470
574
551
448
109
27
2111
1461
1259
1270
263
10
225
584
1440
1797
1898
177
958
1421
1301
573
507
1610
985
439
1571
651
2452
117...

result:

ok 3000 numbers

Test #6:

score: 0
Wrong Answer
time: 16ms
memory: 64496kb

input:

3000 3000
15 64 32 83 23 22 48 7 68 36 43 75 29 17 37 97 92 42 50 87 73 43 12 48 83 44 1 13 23 96 48 60 99 26 2 104 73 73 64 61 64 49 67 94 89 9 96 102 66 19 95 2 29 78 102 61 77 84 34 92 36 31 44 25 68 47 137 131 75 37 21 173 62 44 36 53 19 165 98 100 95 57 85 32 87 69 118 85 24 35 36 98 47 44 92 2...

output:

472
725
430
451
1180
1816
588
778
630
673
1084
883
2835
521
1190
296
2033
380
1931
1481
514
2140
470
1308
410
1183
358
498
410
927
1264
22
37
1698
295
1740
841
565
2546
218
865
987
709
717
4
2290
266
59
167
667
891
28
1057
2212
658
1220
434
1848
571
2204
897
1432
122
1902
1705
540
13
2155
2565
1390
...

result:

wrong answer 1st numbers differ - expected: '467', found: '472'

Test #7:

score: 0
Wrong Answer
time: 17ms
memory: 67356kb

input:

3000 3000
96 48 34 1 27 93 76 3 38 26 79 74 25 95 34 37 5 26 54 37 62 22 17 3 53 34 10 132 64 91 53 34 74 92 64 3 103 38 74 40 31 38 63 12 84 84 80 5 88 22 51 66 28 158 16 31 26 53 47 22 66 89 7 65 91 49 62 73 26 54 13 33 28 45 48 90 91 46 37 34 53 69 70 52 62 71 56 190 154 72 25 6 17 196 66 39 80 5...

output:

1498
792
362
125
301
1016
786
345
661
377
1881
534
308
1493
2322
210
1107
1073
1376
900
1245
1846
1701
65
635
184
921
1729
746
732
301
351
1648
49
66
109
1695
1273
1971
911
1356
359
178
158
120
1870
1796
1237
135
368
772
1509
1646
340
222
60
1133
1653
855
1345
469
268
931
257
926
2246
1779
225
103
1...

result:

wrong answer 1st numbers differ - expected: '1486', found: '1498'

Test #8:

score: 0
Wrong Answer
time: 7ms
memory: 64016kb

input:

3000 3000
24 75 55 19 9 74 4 22 81 77 75 46 60 50 19 50 1 41 8 63 4 47 93 24 105 16 28 76 18 96 1 68 46 80 41 83 78 36 88 45 83 54 67 46 94 99 44 61 14 50 143 97 95 78 8 92 36 59 95 26 67 23 26 95 77 92 98 13 63 149 129 61 74 39 38 55 15 90 48 3 37 39 100 77 18 10 19 10 20 77 71 46 65 84 46 7 175 81...

output:

1594
104
35
1438
1148
1148
7
165
189
1887
492
1155
1428
1535
2
1458
295
631
745
666
2339
532
513
55
347
18
985
279
1052
13
50
1106
634
342
536
2113
635
238
105
85
727
734
1234
497
1648
1426
1795
595
212
161
110
2031
683
2407
1480
1988
731
554
1525
266
66
833
755
2615
833
1266
343
1965
2125
317
2161
...

result:

wrong answer 1st numbers differ - expected: '1585', found: '1594'

Test #9:

score: 5
Accepted
time: 7ms
memory: 67600kb

input:

10000 10000
1225 3839 1022 812 2195 8154 9848 3399 6401 5375 4192 5933 7758 9460 5569 6817 1504 104 7537 509 3830 3790 686 416 5452 4214 2651 2825 5881 4373 2118 8244 8803 5866 1737 5206 3037 4862 5976 2871 9541 6867 2024 8451 7815 1083 5523 8874 1745 828 8022 5706 3404 651 4212 8126 2555 6660 5481 ...

output:

2317
3599
3097
8537
195
960
801
3058
2037
2027
1541
2197
2833
771
5561
4431
1301
2065
256
3479
6754
2226
3446
82
8993
3657
6011
6246
598
6585
3467
5990
790
2676
4614
3817
6507
5410
5632
3388
8482
3403
4104
760
3379
2558
1639
451
3111
2318
6118
1229
6212
120
325
1895
2079
761
1645
961
6468
4078
543
2...

result:

ok 10000 numbers

Test #10:

score: 5
Accepted
time: 3ms
memory: 64792kb

input:

10000 10000
4293 5943 4058 5440 7413 5250 1171 9947 4399 9939 5300 6419 5446 2275 8834 6841 1566 3814 2298 5294 8131 603 2736 4135 946 7071 3233 6196 6458 5162 8229 3087 227 828 7544 3423 7594 4496 8790 4052 8704 3088 7330 7269 5010 9400 9399 3819 302 4258 2985 3323 6455 5755 7489 321 501 3299 2026 ...

output:

2271
2653
444
7140
3433
89
4845
1492
1887
8437
6861
8573
4645
793
3692
252
3903
1326
240
5380
5856
7998
869
935
3332
9302
3509
5279
2656
4559
249
3229
182
7170
7702
2816
2146
343
6988
2396
4375
5391
3239
3598
5485
4816
1364
1058
2125
2865
1456
1488
1427
2608
1075
5964
2398
3960
3400
39
210
866
2766
...

result:

ok 10000 numbers

Test #11:

score: 0
Wrong Answer
time: 19ms
memory: 64680kb

input:

10000 10000
7 178 96 109 117 3 170 302 209 84 248 310 97 70 222 255 276 127 233 219 109 282 8 182 20 128 75 158 39 214 102 260 13 80 276 221 271 319 129 110 72 89 254 45 34 322 310 299 305 32 93 224 5 261 126 140 311 81 100 72 328 312 42 16 231 146 72 238 178 178 179 226 314 152 167 202 295 258 15 2...

output:

3549
3501
6396
272
975
2124
807
3977
2813
8
253
1435
9085
2847
5804
4734
5149
4198
1826
2037
406
5462
6152
2820
4773
3135
23
2013
97
831
4175
4463
312
3883
9021
7847
2114
1775
8010
654
3286
1358
8594
1744
4760
5981
138
5255
3425
866
6281
848
1853
8048
1750
1706
1455
3931
4344
978
1344
3149
4978
4563...

result:

wrong answer 1st numbers differ - expected: '3540', found: '3549'

Test #12:

score: 0
Wrong Answer
time: 8ms
memory: 67484kb

input:

10000 10000
3 31 195 326 322 174 300 177 87 56 74 14 39 240 134 249 176 187 87 118 177 304 269 44 128 328 112 121 96 93 140 163 209 271 29 296 232 309 228 183 238 100 66 118 204 90 156 45 204 126 232 68 318 327 5 3 153 331 180 62 308 172 175 142 88 318 236 75 276 251 67 218 28 118 141 257 65 151 183...

output:

1100
1591
3520
1034
6220
8341
2867
5748
1103
2350
645
2490
470
1128
3824
6102
623
2979
3770
394
3687
3754
4712
6432
4535
8149
6128
421
1503
1258
1168
5109
401
4427
1600
6353
4464
3986
4626
5334
3848
1103
186
4354
9176
1903
9196
209
516
2411
2286
9335
2473
3213
1902
2262
5606
1256
1525
560
7414
2506
...

result:

wrong answer 1st numbers differ - expected: '1097', found: '1100'

Test #13:

score: 5
Accepted
time: 111ms
memory: 68596kb

input:

200000 200000
120536 165588 195015 67563 60504 93355 188680 98879 30412 35909 162690 193085 79065 58869 51576 146413 166618 182838 56146 110147 142857 111033 186246 180779 63081 24777 52683 191278 98735 11504 115999 116939 157422 109468 175004 10755 112531 71163 35398 71262 141229 231 123311 168965 ...

output:

75089
92570
57628
28642
48923
56560
82969
66696
28323
166431
482
38952
118470
122072
50229
3057
79231
79203
13575
72987
45708
144206
30494
58345
162785
75575
74034
10826
4345
9720
140844
20906
52954
88401
63116
19344
118670
165376
112254
89817
57446
88388
122827
55232
102433
128215
134657
2814
13354...

result:

ok 200000 numbers

Test #14:

score: 0
Wrong Answer
time: 112ms
memory: 71524kb

input:

200000 200000
5203 2776 2051 83 5255 4479 6328 3395 5764 3079 4020 4235 31 62 2282 1983 4052 5141 6514 108 45 84 2874 2225 5833 2277 5069 777 3458 4312 6577 1083 18 6003 4773 1935 2908 91 843 5317 6643 103 5581 113 6234 3738 144 3953 1234 396 4543 3518 5508 1833 1674 1446 1134 6455 4343 558 658 3664...

output:

68600
42028
31652
94138
14382
59438
125013
172555
42662
96600
17561
140915
1162
174133
6118
9900
118438
85279
52894
20164
20156
9455
113424
187719
23800
82052
38166
84964
116351
22782
56592
55149
59224
34400
101158
44237
49112
34704
18447
3680
47378
13861
126012
60032
56199
7170
117307
132383
53670
...

result:

wrong answer 1st numbers differ - expected: '68599', found: '68600'

Test #15:

score: 0
Wrong Answer
time: 106ms
memory: 69264kb

input:

200000 200000
5102 3159 748 5427 621 5896 499 5528 1847 6008 961 3084 1541 3370 3477 6551 3122 34 60 5045 1000 2091 119 35 345 92 47 6200 2305 611 27 20 4462 37 1192 108 5020 6490 5834 2997 6615 4662 102 4466 3073 634 2393 278 6122 6451 4679 4161 2316 2074 4859 782 3340 3997 6350 6659 4747 2199 5225...

output:

40301
785
17318
4347
89993
20182
75800
134678
58699
21704
83934
48407
54818
119892
40563
150280
124767
14795
160829
97967
47905
108015
71596
16827
48016
10221
57948
179423
11860
2878
44405
49571
62168
25923
102001
535
23719
7907
13857
66725
69144
130926
4084
25240
7969
57633
145644
93871
82033
24659...

result:

wrong answer 1st numbers differ - expected: '40298', found: '40301'

Test #16:

score: 0
Wrong Answer
time: 95ms
memory: 69308kb

input:

200000 200000
5620 4596 1787 1569 11 3679 57 5561 1635 5384 5280 71 127 4084 4074 4 3533 4939 5115 96 336 75 3997 951 133 6410 4574 3466 3102 534 6321 107 2300 2531 5426 73 20 12 101 607 10 4424 5847 134 6212 862 855 5070 77 91 2010 4014 4678 4050 3695 3451 2790 4235 2235 5998 6354 5149 4794 4789 40...

output:

10116
12795
38742
16171
198057
30975
25821
58772
27237
68613
7180
19914
76375
116048
80161
179220
101801
7814
7875
5180
87645
100501
59664
68174
158008
33935
27897
170247
35523
27229
51583
72335
61600
23423
94060
95366
53059
39938
164713
5891
52220
90683
125199
1897
74160
9318
139109
32573
51283
830...

result:

wrong answer 1st numbers differ - expected: '10114', found: '10116'

Test #17:

score: 5
Accepted
time: 604ms
memory: 93900kb

input:

1000000 1000000
87382 651796 951220 648926 497665 375383 228684 303780 166986 89826 91242 258504 374341 653338 160191 648153 603954 860894 376629 474180 967487 270337 3022 832849 628198 269953 992793 314447 701562 440916 559722 134912 67124 636002 748016 771119 200861 655997 618755 558 882633 709234...

output:

401390
115094
693946
405930
741547
92628
200488
82755
151394
228002
301572
510455
34245
128599
315022
504014
716098
46104
145061
544861
118917
145564
413047
596758
100851
50894
883811
180199
311843
417215
651492
188593
70440
122245
276161
104247
150070
733186
335338
609200
51884
907243
408520
507205...

result:

ok 1000000 numbers

Test #18:

score: 0
Wrong Answer
time: 599ms
memory: 93928kb

input:

1000000 1000000
3228 19 1838 21 15231 54 27226 18805 16744 57 25133 23568 27304 24323 9187 89 14287 13412 20542 21860 23602 65 1 32705 27 20439 19966 70 7865 13967 127 30379 34 95 12820 8224 14188 32692 93 29481 28113 14591 119 7443 2802 6678 51 6838 88 74 7855 95 775 11917 104 18776 34 22985 32134 ...

output:

601779
87979
543642
148209
122260
85819
8159
181384
13906
194238
213330
139436
173156
498628
268392
595815
407089
147647
107033
14141
345536
160972
75778
611055
108847
263612
11065
517146
545514
707810
287961
26601
639846
4459
247024
426993
139158
21859
357766
297219
695773
93735
571717
513912
14232...

result:

wrong answer 1st numbers differ - expected: '601769', found: '601779'

Test #19:

score: 0
Wrong Answer
time: 577ms
memory: 93904kb

input:

1000000 1000000
13910 7760 24228 1793 79 14626 44 10663 25005 56 4240 15833 3609 19816 13269 28175 8807 67 1480 27123 69 12868 11829 3 18390 5510 58 28157 26708 17269 10176 14025 41 7746 12814 9220 24534 115 12446 51 6256 21293 28779 6845 31048 19928 19877 13972 13317 7203 9974 13131 133 13 5348 166...

output:

149910
626070
592293
104662
180045
665743
132510
790600
318338
111443
27229
177448
318907
202118
522930
250087
266067
306172
869714
340297
43428
690080
490529
148545
558744
328421
440533
667794
674179
327417
120950
251402
476754
316603
798087
255042
307462
809211
159191
146510
692649
450114
677106
2...

result:

wrong answer 1st numbers differ - expected: '149909', found: '149910'

Test #20:

score: 0
Wrong Answer
time: 588ms
memory: 93928kb

input:

1000000 1000000
15899 2139 32955 19636 21943 29782 28207 9095 20266 68 15471 14533 17782 21804 31540 21751 19168 15466 19302 34 24617 3544 66 31466 31516 3341 30147 6947 26716 135 11544 50 30167 5 11 7820 149 5146 32617 20175 23019 23260 8830 16538 88 2357 22200 21845 2144 12436 104 31 24930 10455 1...

output:

127369
622425
88971
350121
62062
220828
468822
369359
696638
227042
194506
770567
698572
327860
58033
172060
19269
81502
11205
448633
621742
574040
298980
855995
21123
532378
932578
240276
256810
655263
96671
280071
640385
191921
328378
350254
422646
246034
781640
152853
111852
532545
705788
191469
...

result:

wrong answer 1st numbers differ - expected: '127368', found: '127369'