QOJ.ac

QOJ

IDProblemSubmitterResultTimeMemoryLanguageFile sizeSubmit timeJudge time
#290682#441. 制作菜品MoRanSky100 ✓693ms314264kbC++232.0kb2023-12-25 06:25:482023-12-25 06:25:50

Judging History

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

  • [2023-12-25 06:25:50]
  • 评测
  • 测评结果:100
  • 用时:693ms
  • 内存:314264kb
  • [2023-12-25 06:25:48]
  • 提交

answer

#include <iostream>
#include <cstdio>
#include <algorithm>
#include <bitset>
using namespace std;

const int N = 505, M = 5005;

int k, O;

bool vis[N];

struct Mate{
	int d, p;
	bool operator < (const Mate &b) const {
		return d < b.d;
	}
} e[N], g[N];

// solve: n - 1 = m
void inline solve1(int n, int m) {
	if (m == 0) return;
	sort(e + 1, e + 1 + n);
	if (m == 1) {
		int i = e[1].p, x = e[1].d, j = e[2].p, y = e[2].d;
		if (x) printf("%d %d %d %d\n", i, x, j, y);
		else printf("%d %d\n", j, y);
		return;
	}
	int i = e[1].p, x = e[1].d, j = e[n].p, y = k - e[1].d;
	if (x) printf("%d %d %d %d\n", i, x, j, y);
	else printf("%d %d\n", j, y);
	e[1].p = e[n].p, e[1].d = e[n].d - y;
	solve1(n - 1, m - 1);
}

 

// solve: n <= m
void inline solve2(int n, int m) {
	if (n - 1 == m) solve1(n, m);
	else {
		sort(e + 1, e + 1 + n);
		int i = e[n].p, x = k;
		printf("%d %d\n", i, x);
		e[n].d -= x;
		solve2(n, m - 1);
	}
}

bitset<N * M * 2> f[N];

//solve: n - 2 = m;

void inline work(int i, int j) {
	if (i == 0 || j == O) return;
	if (f[i - 1].test(j)) work(i - 1, j);
	else vis[i] = true, work(i - 1, j - (e[i].d - k));
}

void inline solve3(int n, int m) {
	if (m == 1) { puts("-1"); return; }
	O = m * k;
	for (int i = 1; i <= n; i++) g[i] = e[i], vis[i] = false;
	f[0].reset(), f[0].set(O);
	for (int i = 1; i <= n; i++) {
		int v = e[i].d - k;
		if (v >= 0) f[i] = f[i - 1] | (f[i - 1] << v);
		else f[i] = f[i - 1] | (f[i - 1] >> (-v));
	}
	if (!f[n].test(O - k)) { puts("-1"); return; }
	work(n, O - k);
	int tot = 0;
	for (int i = 1; i <= n; i++)
		if (vis[i]) e[++tot] = g[i];
	solve1(tot, tot - 1);
	tot = 0;
	for (int i = 1; i <= n; i++) if (!vis[i]) e[++tot] = g[i];
	solve2(tot, tot - 1);
}

int main() {
	int T; scanf("%d", &T);
	while (T--) {
		int n, m; 
		scanf("%d%d%d", &n, &m, &k);
		for (int i = 1; i <= n; i++) scanf("%d", &e[i].d), e[i].p = i;
		if (n - 1 == m) solve1(n, m);
		else if (n <= m) solve2(n, m);
		else solve3(n, m);
	}
	return 0;
}

Details

Tip: Click on the bar to expand more detailed information

Test #1:

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

input:

10
4 2 50
13 39 35 13
4 3 45
19 55 34 27
4 3 47
18 33 20 70
4 2 48
5 8 40 43
4 2 47
8 37 25 24
4 2 46
1 10 45 36
4 2 49
2 5 47 44
4 2 49
34 31 25 8
4 2 45
27 31 21 11
4 2 50
35 12 27 26

output:

-1
1 19 2 26
4 27 3 18
3 16 2 29
1 18 4 29
3 20 4 27
4 14 2 33
2 8 3 40
1 5 4 43
-1
1 1 3 45
2 10 4 36
1 2 3 47
2 5 4 44
-1
-1
-1

result:

ok OK both got answer: NYYYNYYNNN

Test #2:

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

input:

10
4 2 50
16 24 30 30
4 3 47
2 79 53 7
4 3 50
32 61 44 13
4 2 50
1 6 44 49
4 2 47
19 21 26 28
4 2 46
10 10 36 36
4 2 46
5 2 41 44
4 2 47
33 29 26 6
4 2 45
34 32 23 1
4 2 45
27 11 29 23

output:

-1
1 2 2 45
4 7 3 40
3 13 2 34
4 13 2 37
2 24 3 26
3 18 1 32
2 6 3 44
1 1 4 49
2 21 3 26
1 19 4 28
1 10 3 36
2 10 4 36
1 5 3 41
2 2 4 44
-1
-1
-1

result:

ok OK both got answer: NYYYYYYNNN

Test #3:

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

input:

10
4 2 50
30 24 22 24
4 4 49
27 2 82 85
4 3 48
25 7 58 54
4 2 49
7 2 42 47
4 2 48
24 17 29 26
4 2 47
5 2 42 45
4 2 47
1 5 46 42
4 2 49
41 27 13 17
4 2 45
32 38 1 19
4 2 48
2 37 27 30

output:

-1
4 49
2 2 3 47
1 27 4 22
4 14 3 35
2 7 3 41
3 17 4 31
4 23 1 25
1 7 3 42
2 2 4 47
-1
1 5 3 42
2 2 4 45
1 1 3 46
2 5 4 42
-1
-1
-1

result:

ok OK both got answer: NYYYNYYNNN

Test #4:

score: 5
Accepted
time: 12ms
memory: 11600kb

input:

10
10 8 5000
5342 2288 3662 4105 4769 3942 5355 3406 4746 2385
10 9 4698
1039 6862 6700 5529 5825 3904 2539 5303 3551 1030
10 10 4730
4387 531 7610 2566 236 4490 2510 8625 8084 8261
10 8 4806
1147 891 10 173 1046 1138 853 1176 11527 20487
10 8 4719
6495 10158 2542 2599 2552 2821 2521 2457 2778 2829
...

output:

-1
10 1030 2 3668
1 1039 3 3659
7 2539 5 2159
3 3041 4 1657
2 3194 8 1504
9 3551 6 1147
6 2757 4 1941
4 1931 8 2767
8 1032 5 3666
8 4730
5 236 10 4494
2 531 9 4199
7 2510 3 2220
4 2566 3 2164
3 3226 6 1504
6 2986 1 1744
1 2643 8 2087
8 1808 9 2922
9 963 10 3767
7 853 9 3953
2 891 9 3915
1 1147 9 365...

result:

ok OK both got answer: NYYYYYYNNY

Test #5:

score: 5
Accepted
time: 12ms
memory: 11664kb

input:

10
10 8 5000
6157 6740 2393 3458 2043 1360 6248 1866 4221 5514
10 9 4538
2843 5424 4477 3285 6508 6308 1055 2505 3471 4966
10 10 4768
7647 4253 6258 1620 1896 5150 4265 7169 3108 6314
10 8 4530
203 386 695 553 454 907 161 138 7699 25044
10 8 4749
12629 3640 2377 2953 3034 2552 2594 2539 2971 2703
10...

output:

-1
7 1055 5 3483
8 2505 6 2033
1 2843 2 1695
5 3025 10 1513
4 3285 3 1253
3 3224 6 1314
6 2961 2 1577
2 2152 9 2386
9 1085 10 3453
1 4768
4 1620 8 3148
5 1896 10 2872
1 2879 3 1889
9 3108 6 1660
10 3442 3 1326
3 3043 7 1725
7 2540 2 2228
2 2025 8 2743
8 1278 6 3490
5 454 9 4076
6 907 9 3623
8 138 10...

result:

ok OK both got answer: NYYYNYYNNN

Test #6:

score: 5
Accepted
time: 8ms
memory: 3888kb

input:

10
500 499 5000
3843 636 8549 185 5830 892 8932 7825 5651 7620 6940 2405 7094 3940 1386 8882 8067 4484 5330 6806 6447 8253 1493 2867 4309 4942 2164 5890 4198 7743 7659 8054 8378 6352 8239 4353 7245 7315 2322 3040 5080 9262 5445 2318 3346 6831 1345 1557 1459 6674 8363 7906 5072 1 917 9381 4943 3081 5...

output:

54 1 141 4999
123 4 112 4996
210 20 348 4980
411 56 130 4944
458 60 468 4940
160 88 100 4912
71 143 262 4857
487 163 285 4837
263 180 353 4820
248 180 198 4820
4 185 221 4815
479 209 431 4791
287 311 65 4689
343 327 500 4673
390 329 467 4671
116 341 404 4659
166 408 306 4592
430 502 239 4498
164 506...

result:

ok OK both got answer: YYYYYYYYYY

Test #7:

score: 5
Accepted
time: 8ms
memory: 3712kb

input:

10
500 499 5000
6364 9285 10151 6902 4812 383 1398 4035 1971 9873 7569 5965 325 5298 1360 8638 1972 5110 4572 251 3205 9987 5918 5656 9501 10136 6777 5295 1349 9650 5545 7712 8543 5303 4221 2961 5686 5619 6996 7657 5099 4172 3229 5425 9470 4589 3669 1048 9699 8241 1300 2511 7835 7218 8167 6943 6961 ...

output:

372 57 152 4943
193 84 267 4916
255 149 294 4851
287 155 368 4845
361 211 143 4789
92 233 442 4767
120 242 138 4758
20 251 170 4749
137 257 204 4743
471 275 72 4725
265 298 3 4702
379 305 387 4695
13 325 26 4675
476 356 348 4644
237 360 332 4640
6 383 446 4617
450 383 277 4617
178 405 22 4595
312 42...

result:

ok OK both got answer: YYYYYYYYYY

Test #8:

score: 5
Accepted
time: 153ms
memory: 3652kb

input:

10
500 499 5000
3262 2165 5773 7999 8262 4733 3525 9726 2951 1150 7415 3911 8271 1083 1070 2438 5462 121 3183 3406 4427 604 9652 7737 3618 9228 586 3865 8022 5399 2492 1306 7564 8264 9304 5848 3019 2852 5597 5971 4002 3034 9882 2296 4117 974 4734 9579 1096 7917 3007 5522 8522 2682 3282 2162 1932 386...

output:

153 54 442 4946
430 63 60 4937
179 65 242 4935
213 80 301 4920
432 88 194 4912
189 92 451 4908
458 103 168 4897
347 109 291 4891
18 121 43 4879
336 145 409 4855
364 163 395 4837
461 166 109 4834
438 167 68 4833
254 206 352 4794
398 208 92 4792
351 228 233 4772
102 248 212 4752
279 292 75 4708
367 30...

result:

ok OK both got answer: YYYYYYYYYY

Test #9:

score: 5
Accepted
time: 79ms
memory: 3600kb

input:

10
500 499 5000
376 381 6759 4321 1893 4083 656 572 8961 7703 7497 2069 1181 1998 5786 6456 3949 5274 1870 1472 749 1478 8484 20 7946 3563 4574 2497 9538 6433 9457 9905 6814 6258 4268 8707 384 4925 9279 9345 2670 6818 1456 3851 8816 7242 349 2808 2558 2219 4280 3308 3697 2806 3327 1685 6369 7902 418...

output:

197 10 67 4990
24 20 65 4980
383 29 453 4971
170 31 299 4969
259 45 32 4955
92 49 360 4951
457 82 263 4918
257 100 470 4900
478 145 71 4855
462 181 143 4819
109 189 466 4811
66 208 87 4792
364 228 162 4772
230 236 235 4764
239 237 376 4763
243 245 346 4755
408 258 29 4742
47 349 248 4651
68 366 499 ...

result:

ok OK both got answer: YYYYYYYYYY

Test #10:

score: 5
Accepted
time: 28ms
memory: 20884kb

input:

10
25 23 5000
1582 1893 7547 6423 6090 3892 4873 4774 2419 2735 5981 2688 3103 6615 6641 5380 2563 5787 7635 7001 1653 7130 6048 1202 3345
25 4081 4766
1369984 261096 700757 803287 573341 1074135 738958 287371 722477 1506529 1248259 111432 430938 235065 1290857 961063 846904 1042705 718050 355187 15...

output:

1 1582 4 3418
4 3005 6 1995
6 1897 13 3103
24 1202 19 3798
21 1653 3 3347
2 1893 22 3107
9 2419 20 2581
17 2563 15 2437
12 2688 14 2312
10 2735 5 2265
25 3345 23 1655
5 3825 11 1175
19 3837 18 1163
22 4023 16 977
3 4200 7 800
7 4073 11 927
11 3879 8 1121
8 3653 18 1347
18 3277 20 1723
20 2697 16 230...

result:

ok OK both got answer: YYYYYYYYYN

Test #11:

score: 5
Accepted
time: 29ms
memory: 21152kb

input:

10
25 1181 462
27553 24516 201 15428 23094 32388 21669 7407 32798 40696 20339 22360 33207 21199 22486 32400 30281 21768 20176 4462 2709 25794 34237 21829 6625
25 23 490
56 500 3 104 62 39 17 83 10 110 44 14 16 94 30 43 51 4 117 65 16 102 456 4806 4428
25 23 480
47 75 21 508 41 3 48 57 10 70 589 96 5...

output:

10 462
10 462
10 462
10 462
10 462
10 462
10 462
10 462
10 462
10 462
10 462
10 462
10 462
10 462
23 462
10 462
23 462
10 462
23 462
10 462
13 462
23 462
10 462
9 462
13 462
16 462
23 462
6 462
10 462
9 462
13 462
16 462
23 462
6 462
10 462
9 462
13 462
16 462
23 462
6 462
10 462
9 462
13 462
16 462...

result:

ok OK both got answer: YYYYYYYYYN

Test #12:

score: 5
Accepted
time: 34ms
memory: 21164kb

input:

10
25 1996 459
42271 3951 22551 39538 47172 12207 69249 32050 23450 71343 14663 50987 57351 29133 43127 42623 60062 37544 15504 39007 49586 17876 2088 70962 21869
25 23 492
68 65 77 77 12 8 40 58 24 93 5 46 69 1 92 48 75 56 43 44 111 3 2 4572 5627
25 23 470
496 17 88 437 56 86 66 38 86 86 92 13 100 ...

output:

10 459
24 459
10 459
24 459
10 459
24 459
10 459
24 459
10 459
7 459
24 459
10 459
7 459
24 459
10 459
7 459
24 459
10 459
7 459
24 459
10 459
7 459
24 459
10 459
7 459
24 459
10 459
7 459
24 459
10 459
7 459
24 459
10 459
7 459
24 459
10 459
7 459
24 459
10 459
7 459
24 459
10 459
7 459
24 459
10 4...

result:

ok OK both got answer: YYYYYYYYYY

Test #13:

score: 5
Accepted
time: 52ms
memory: 30180kb

input:

10
40 2512 475
13292 14201 12975 71320 26633 55182 40472 7861 24905 21752 36640 22060 55829 23162 33190 44623 15134 24868 26316 10462 6520 35857 72022 31604 16527 10443 72278 20073 4676 30582 16987 17966 44783 29963 16708 71415 12567 57181 6699 37472
40 38 459
62 59 50 64 101 45 19 48 66 23 56 10 34...

output:

27 475
23 475
27 475
23 475
36 475
27 475
4 475
23 475
36 475
27 475
4 475
23 475
36 475
27 475
4 475
23 475
36 475
27 475
4 475
23 475
36 475
27 475
4 475
23 475
36 475
27 475
4 475
23 475
36 475
27 475
4 475
23 475
36 475
27 475
4 475
23 475
36 475
27 475
4 475
23 475
36 475
27 475
4 475
23 475
36...

result:

ok OK both got answer: YYYYYYYYYN

Test #14:

score: 5
Accepted
time: 76ms
memory: 36288kb

input:

10
50 2076 493
13768 16083 2191 44149 4290 40590 31917 13314 17253 29746 38642 43320 35890 11453 39167 6759 4608 7908 24128 12150 47546 11145 21662 18819 6855 1750 32550 19098 14245 39372 8714 28012 7662 10904 24369 11953 3702 8493 25267 20955 38239 16116 16483 26336 27570 7857 33095 32177 15765 943...

output:

21 493
21 493
21 493
21 493
21 493
21 493
21 493
4 493
21 493
4 493
21 493
12 493
4 493
21 493
12 493
4 493
21 493
12 493
4 493
21 493
12 493
4 493
21 493
12 493
4 493
21 493
12 493
4 493
21 493
6 493
12 493
4 493
21 493
6 493
12 493
4 493
21 493
6 493
12 493
30 493
4 493
15 493
21 493
6 493
12 493
...

result:

ok OK both got answer: YYYYYYYYYY

Test #15:

score: 5
Accepted
time: 129ms
memory: 55088kb

input:

10
80 78 5000
8040 5713 8368 9134 8571 8109 7586 4125 7300 8857 8252 4188 5699 4785 6890 1459 1717 1611 4490 4584 6110 8045 3749 9170 3825 7975 5314 8649 3411 305 4924 2083 6018 3925 1850 5222 2667 69 9347 600 8926 8232 4789 5258 3649 2312 6717 5367 3923 1840 584 665 518 4333 468 4342 2941 5782 3624...

output:

16 1459 11 3541
18 1611 11 3389
11 1322 19 3678
19 812 12 4188
38 69 39 4931
30 305 24 4695
55 468 4 4532
53 518 41 4482
72 545 10 4455
51 584 28 4416
40 600 5 4400
52 665 62 4335
66 917 63 4083
69 986 3 4014
76 1087 42 3913
17 1717 6 3283
74 1795 22 3205
50 1840 1 3160
35 1850 80 3150
32 2083 26 29...

result:

ok OK both got answer: YYYYNYYYYY

Test #16:

score: 5
Accepted
time: 132ms
memory: 61260kb

input:

10
90 88 5000
5484 8888 12 5876 2700 2940 353 5052 3730 1150 3821 2601 3969 1124 6851 5536 493 6681 3568 7776 2861 4548 2986 6888 3620 7790 9415 3136 606 6329 2623 6092 5736 2634 2487 8436 5574 2840 4007 9305 3991 7828 2425 7960 8952 9276 4015 9445 6476 7583 7739 9337 2650 1244 6744 6271 9034 6678 9...

output:

3 12 15 4988
15 1863 1 3137
1 2347 8 2653
8 2399 12 2601
85 28 48 4972
60 159 27 4841
83 171 59 4829
80 315 52 4685
7 353 84 4647
17 493 40 4507
79 525 46 4475
76 562 64 4438
29 606 88 4394
73 1091 57 3909
71 1100 45 3900
14 1124 2 3876
10 1150 66 3850
54 1244 78 3756
68 1277 36 3723
69 2098 82 2902...

result:

ok OK both got answer: YYYYYYYYYY

Test #17:

score: 5
Accepted
time: 163ms
memory: 67396kb

input:

10
100 98 5000
8022 7712 6112 7663 1520 7578 2583 6276 5066 2892 9298 943 7244 2199 7090 5023 4145 2293 2574 1382 4442 5853 2144 4654 3331 2729 4068 7165 7453 7925 4978 5351 5506 959 2884 7027 8537 5467 3172 3473 8359 2340 4415 5473 4539 1375 365 8684 3668 2939 10066 8110 8792 2079 2633 1992 4807 67...

output:

12 943 2 4057
5 1520 6 3480
14 2199 15 2801
10 2892 9 2108
9 2958 15 2042
15 2247 6 2753
6 1345 2 3655
66 234 70 4766
47 365 51 4635
34 959 64 4041
96 1092 78 3908
74 1128 75 3872
84 1236 11 3764
46 1375 59 3625
20 1382 53 3618
94 1543 48 3457
97 1776 37 3224
56 1992 41 3008
88 2063 52 2937
54 2079 ...

result:

ok OK both got answer: YYYYYYYYYN

Test #18:

score: 5
Accepted
time: 460ms
memory: 190688kb

input:

10
300 298 5000
5030 5827 7011 8862 5150 6830 4727 2114 6063 4511 4362 9088 205 3225 1864 4129 7690 7517 1429 9553 5840 1890 1254 2099 7836 7291 3302 1049 9208 4207 2303 4386 173 9314 3387 5323 6283 8114 7436 2484 2764 1937 1711 2969 5163 3575 7098 2992 1231 8527 2684 7072 556 3938 9171 8392 1368 26...

output:

13 205 3 4795
8 2114 9 2886
3 2216 2 2784
2 3043 5 1957
9 3177 1 1823
5 3193 7 1807
7 2920 10 2080
10 2431 11 2569
11 1793 1 3207
70 29 95 4971
133 52 256 4948
209 130 78 4870
244 143 296 4857
117 162 143 4838
152 171 207 4829
259 173 252 4827
33 173 100 4827
138 174 20 4826
195 219 266 4781
71 241 ...

result:

ok OK both got answer: YYYYYYYYYY

Test #19:

score: 5
Accepted
time: 613ms
memory: 252388kb

input:

10
400 398 5000
2279 4205 8320 5468 9047 6440 1995 3019 2232 1218 9740 2414 8351 9403 6770 8485 6427 2827 5318 2800 2239 8052 101 4435 7548 1757 2323 4880 899 209 4509 3183 4414 2567 8651 3200 9007 384 6218 977 1602 5697 3391 9954 4839 10161 8177 1005 2727 3234 3804 4966 1025 3906 9401 8573 5663 146...

output:

10 1218 5 3782
9 2232 13 2768
1 2279 6 2721
12 2414 13 2586
13 2997 5 2003
8 3019 6 1981
6 1738 5 3262
65 7 302 4993
87 40 394 4960
159 52 224 4948
324 59 301 4941
82 65 158 4935
23 101 152 4899
299 139 374 4861
234 146 165 4854
225 175 46 4825
30 209 72 4791
247 232 271 4768
223 233 341 4767
295 25...

result:

ok OK both got answer: YYYYYYYYYY

Test #20:

score: 5
Accepted
time: 693ms
memory: 314264kb

input:

10
500 498 5000
9985 2503 9725 1832 2649 714 9735 4079 8786 8366 10289 598 6536 5521 1487 2592 5197 8514 9590 6334 3817 4141 4407 7125 7338 1365 6816 9153 2880 6832 1744 2229 9336 833 4061 1349 1547 3160 5428 10333 890 5081 296 7426 10602 1783 10018 5163 10297 8971 861 3478 2476 5268 10603 9814 6633...

output:

12 598 11 4402
6 714 1 4286
4 1832 11 3168
2 2503 1 2497
11 2719 8 2281
8 1798 1 3202
323 11 166 4989
265 43 161 4957
177 48 354 4952
395 59 55 4941
433 64 45 4936
481 76 351 4924
125 105 98 4895
390 125 162 4875
447 125 163 4875
300 128 369 4872
135 134 437 4866
230 137 40 4863
282 223 471 4777
400...

result:

ok OK both got answer: YYYYYYYYYY

Extra Test:

score: 0
Extra Test Passed