Task: | Education |
Sender: | KnowYourArchitecture |
Submission time: | 2017-10-31 20:01:15 +0200 |
Language: | C++ |
Status: | READY |
Result: | ACCEPTED |
test | verdict | time | |
---|---|---|---|
#1 | ACCEPTED | 0.04 s | details |
#2 | ACCEPTED | 0.04 s | details |
#3 | ACCEPTED | 0.04 s | details |
#4 | ACCEPTED | 0.04 s | details |
#5 | ACCEPTED | 0.05 s | details |
#6 | ACCEPTED | 0.06 s | details |
#7 | ACCEPTED | 0.07 s | details |
#8 | ACCEPTED | 0.07 s | details |
#9 | ACCEPTED | 0.05 s | details |
#10 | ACCEPTED | 0.06 s | details |
#11 | ACCEPTED | 0.05 s | details |
#12 | ACCEPTED | 0.05 s | details |
#13 | ACCEPTED | 0.03 s | details |
#14 | ACCEPTED | 0.04 s | details |
#15 | ACCEPTED | 0.04 s | details |
#16 | ACCEPTED | 0.04 s | details |
#17 | ACCEPTED | 0.03 s | details |
#18 | ACCEPTED | 0.06 s | details |
Code
#include <bits/stdc++.h> using namespace std; int dep[5001]; int rent[5001]; int cap[5001]; int taken[5001]; int asd[5001]; int main() { int n, m; cin >> n >> m; vector<pair<int, int>> deps; vector<pair<int, pair<int, int>>> bs; for(int i=0;i<n;i++) { cin >> dep[i]; deps.push_back({-dep[i], i}); } for(int i=0;i<m;i++) cin >> cap[i]; for(int i=0;i<m;i++) cin >> rent[i]; for(int i=0;i<m;i++) { bs.push_back({rent[i], {cap[i], i}}); } sort(bs.begin(), bs.end()); sort(deps.begin(), deps.end()); int ndep = 0; for(auto dep : deps) { int needed = -dep.first; for(int i=0;i<m;i++) { auto consider = bs[i]; if(consider.second.first >= needed && !taken[consider.second.second]) { taken[consider.second.second] = true; asd[dep.second] = consider.second.second; ndep++; break; } } } if(ndep != n) { cout << "impossible" << endl; } else { for(int i=0;i<n;i++) { cout << asd[i]+1 << " "; } cout << endl; } return 0; }
Test details
Test 1
Verdict: ACCEPTED
input |
---|
2 3 1 2 2 1 2 1 1 2 |
correct output |
---|
2 1 |
user output |
---|
2 1 |
Test 2
Verdict: ACCEPTED
input |
---|
100 400 405 604 662 507 209 320 336 94... |
correct output |
---|
183 205 248 236 150 50 169 42 ... |
user output |
---|
183 205 248 236 150 50 169 42 ... |
Test 3
Verdict: ACCEPTED
input |
---|
100 400 596 494 947 89 739 940 923 190... |
correct output |
---|
296 159 51 231 329 38 47 75 46... |
user output |
---|
296 159 51 231 329 38 47 75 46... |
Test 4
Verdict: ACCEPTED
input |
---|
100 400 545 934 613 647 534 10 587 305... |
correct output |
---|
impossible |
user output |
---|
impossible |
Test 5
Verdict: ACCEPTED
input |
---|
100 4000 314 533 236 932 593 139 397 73... |
correct output |
---|
3230 1223 242 3511 2586 1530 1... |
user output |
---|
3230 1223 242 3511 2586 1530 1... |
Test 6
Verdict: ACCEPTED
input |
---|
100 4000 498 47 243 573 606 538 182 622... |
correct output |
---|
505 1476 2870 3282 2624 1889 3... |
user output |
---|
505 1693 2870 1177 2624 1889 3... |
Test 7
Verdict: ACCEPTED
input |
---|
4000 5000 992 110 627 188 444 785 607 12... |
correct output |
---|
impossible |
user output |
---|
impossible |
Test 8
Verdict: ACCEPTED
input |
---|
4000 5000 981 602 417 68 723 17 189 349 ... |
correct output |
---|
impossible |
user output |
---|
impossible |
Test 9
Verdict: ACCEPTED
input |
---|
2000 5000 942 801 7 58 865 535 63 925 45... |
correct output |
---|
2654 2673 4524 642 3560 4043 3... |
user output |
---|
1375 1696 3937 3576 2437 4043 ... |
Test 10
Verdict: ACCEPTED
input |
---|
2000 5000 346 342 325 791 867 387 167 43... |
correct output |
---|
2155 1691 1107 4196 3676 396 7... |
user output |
---|
3343 3359 1973 3461 3676 856 4... |
Test 11
Verdict: ACCEPTED
input |
---|
2000 5000 379 181 81 244 67 138 311 763 ... |
correct output |
---|
609 2016 34 1828 252 2270 4016... |
user output |
---|
2351 1396 2992 3685 4355 4198 ... |
Test 12
Verdict: ACCEPTED
input |
---|
2000 5000 699 504 823 38 915 215 167 649... |
correct output |
---|
2127 3976 4307 4103 2537 2779 ... |
user output |
---|
3912 963 2739 2831 2494 3978 1... |
Test 13
Verdict: ACCEPTED
input |
---|
1000 5000 769 231 535 397 155 434 183 71... |
correct output |
---|
2149 4078 402 3128 1111 190 40... |
user output |
---|
3194 1546 3323 1158 880 190 40... |
Test 14
Verdict: ACCEPTED
input |
---|
1000 5000 709 604 503 881 60 756 49 428 ... |
correct output |
---|
1871 3716 4183 3032 2328 731 1... |
user output |
---|
4578 3716 4183 1495 2328 3233 ... |
Test 15
Verdict: ACCEPTED
input |
---|
500 5000 41 585 417 384 533 606 594 601... |
correct output |
---|
4475 3687 4699 1002 1733 2047 ... |
user output |
---|
4475 3774 4699 126 290 2913 26... |
Test 16
Verdict: ACCEPTED
input |
---|
500 5000 812 250 707 106 652 202 79 336... |
correct output |
---|
453 2854 3746 2833 2181 4988 2... |
user output |
---|
453 1357 3746 3256 2181 4450 2... |
Test 17
Verdict: ACCEPTED
input |
---|
500 5000 607 412 339 886 191 583 330 80... |
correct output |
---|
4477 2936 2069 2026 4103 1012 ... |
user output |
---|
3480 1377 2069 2977 4103 1012 ... |
Test 18
Verdict: ACCEPTED
input |
---|
5000 5000 2 3 4 5 6 7 8 9 10 11 12 13 14... |
correct output |
---|
4001 4002 4003 4004 4005 4006 ... |
user output |
---|
1 2 3 4 5 6 7 8 9 10 11 12 13 ... |