QOJ.ac
QOJ
ID | 题目 | 提交者 | 结果 | 用时 | 内存 | 语言 | 文件大小 | 提交时间 | 测评时间 |
---|---|---|---|---|---|---|---|---|---|
#533399 | #5081. Forbidden Turns | skrghariapa# | AC ✓ | 769ms | 45060kb | C++14 | 2.0kb | 2024-08-25 21:58:04 | 2024-08-25 21:58:04 |
Judging History
answer
#include <bits/stdc++.h>
#define int long long int
using namespace std;
const int INF = 1e17;
struct cmp {
bool operator()(const pair<pair<int, int>, int>& a, const pair<pair<int, int>, int>& b) {
return a.second > b.second;
}
};
void solve() {
int m, n, k;
cin >> m >> n >> k;
int src, to;
cin >> src >> to;
vector <int> nino;
vector<vector<pair<int, int>>> adj(n + 1);
for (int i = 0; i < m; i++) {
int u, v, cost;
cin >> u >> v >> cost;
adj[u].emplace_back(v, cost);
if (v == to) {
nino.push_back(u);
}
}
set<tuple<int, int, int>> forbidden;
for (int i = 0; i < k; i++) {
int u, v, w;
cin >> u >> v >> w;
forbidden.emplace(u, v, w);
}
if (src == to) {
cout << 0 << '\n';
return;
}
map<pair<int, int>, int> dist;
priority_queue<pair<pair<int, int>, int>, vector<pair<pair<int, int>, int>>, cmp> pq;
for (const auto& [v, cost]: adj[src]) {
pair<int, int> startEdge = {src, v};
dist[startEdge] = cost;
pq.emplace(startEdge, cost);
}
while (!pq.empty()) {
auto [currVertex, currCost] = pq.top();
pq.pop();
int u = currVertex.first;
int v = currVertex.second;
if (dist[currVertex] < currCost) continue;
for (const auto& [w, cost]: adj[v]) {
pair<int, int> nextVertex = {v, w};
if (forbidden.find({u, v, w}) != forbidden.end()) continue;
int newDist = currCost + cost;
if (dist.find(nextVertex) == dist.end() || newDist < dist[nextVertex]) {
dist[nextVertex] = newDist;
pq.emplace(nextVertex, newDist);
}
}
}
int minDist = INF;
for (const auto mmm: nino) {
pair<int, int> endEdge = {mmm, to};
if (dist.find(endEdge) != dist.end()) {
minDist = min(minDist, dist[endEdge]);
}
}
if (minDist == INF) {
cout << -1 << '\n';
} else {
cout << minDist << '\n';
}
}
int32_t main() {
int t = 1;
// cin >> t;
while (t--) {
solve();
}
}
详细
Test #1:
score: 100
Accepted
time: 0ms
memory: 3616kb
input:
9 7 3 3 2 6 3 2 3 0 3 0 1 12 1 0 4 1 2 2 1 5 4 4 1 8 5 4 7 5 2 5 0 1 2 4 1 5 1 5 2
output:
36
result:
ok single line: '36'
Test #2:
score: 0
Accepted
time: 0ms
memory: 3492kb
input:
4 4 1 0 3 0 1 2 1 2 3 0 2 7 2 3 10 0 1 2
output:
17
result:
ok single line: '17'
Test #3:
score: 0
Accepted
time: 0ms
memory: 3548kb
input:
4 4 0 0 3 0 1 2 1 2 3 0 2 7 2 3 10
output:
15
result:
ok single line: '15'
Test #4:
score: 0
Accepted
time: 0ms
memory: 3584kb
input:
4 4 1 1 0 1 2 3 2 3 10 3 2 12 2 0 7 1 2 0
output:
32
result:
ok single line: '32'
Test #5:
score: 0
Accepted
time: 0ms
memory: 3540kb
input:
13 8 5 0 5 0 2 3 2 1 7 4 2 10 2 3 10 3 2 12 2 5 10 3 6 10 6 7 5 7 3 5 6 4 10 4 1 0 1 4 10 4 6 10 0 2 1 0 2 5 3 2 5 2 3 2 6 4 2
output:
63
result:
ok single line: '63'
Test #6:
score: 0
Accepted
time: 0ms
memory: 3608kb
input:
4 4 2 1 0 1 2 3 2 3 10 3 2 12 2 0 7 1 2 0 2 3 2
output:
-1
result:
ok single line: '-1'
Test #7:
score: 0
Accepted
time: 0ms
memory: 3808kb
input:
4 4 0 1 0 1 2 3 2 3 2 3 2 3 2 0 7
output:
10
result:
ok single line: '10'
Test #8:
score: 0
Accepted
time: 0ms
memory: 3616kb
input:
0 1 0 0 0
output:
0
result:
ok single line: '0'
Test #9:
score: 0
Accepted
time: 74ms
memory: 10880kb
input:
59996 30000 29997 0 29999 0 1 3 1 29999 7 1 2 1 2 1 1 2 3 1 3 2 1 3 4 1 4 3 1 4 5 1 5 4 1 5 6 1 6 5 1 6 7 1 7 6 1 7 8 1 8 7 1 8 9 1 9 8 1 9 10 1 10 9 1 10 11 1 11 10 1 11 12 1 12 11 1 12 13 1 13 12 1 13 14 1 14 13 1 14 15 1 15 14 1 15 16 1 16 15 1 16 17 1 17 16 1 17 18 1 18 17 1 18 19 1 19 18 1 19 2...
output:
60004
result:
ok single line: '60004'
Test #10:
score: 0
Accepted
time: 208ms
memory: 16780kb
input:
54776 10000 149059 0 9999 0 1168 720 0 7849 347 0 5301 937 0 1176 113 0 4762 833 0 6595 630 0 5846 548 0 528 878 1 3794 680 1 5036 171 1 4938 977 1 3180 522 1 9790 3 1 2139 221 1 3003 470 2 1054 534 2 5405 899 2 8279 740 2 1749 864 2 4634 773 2 7027 960 2 8151 321 2 4893 201 3 960 939 4 2349 671 5 6...
output:
2041
result:
ok single line: '2041'
Test #11:
score: 0
Accepted
time: 209ms
memory: 16972kb
input:
54727 10000 149795 0 9999 0 2611 51 0 6360 105 0 9596 66 0 7534 845 0 8007 758 0 1455 356 1 5761 949 1 5075 518 1 9029 436 1 432 235 1 4260 356 1 2845 870 1 5620 793 1 8169 483 2 4993 131 2 5942 50 2 3295 965 2 8977 538 3 8231 754 3 3852 321 3 3800 424 3 1731 493 4 5578 42 4 4697 337 4 3900 54 4 444...
output:
2572
result:
ok single line: '2572'
Test #12:
score: 0
Accepted
time: 208ms
memory: 17068kb
input:
55101 10000 151145 0 9999 0 8800 169 0 1752 969 1 6634 310 1 3693 284 1 1650 910 1 5991 323 1 2499 279 1 5189 154 1 4153 425 2 5566 738 2 2769 947 3 7442 71 3 4856 367 3 1109 398 3 6801 846 4 8109 118 4 290 414 4 315 259 4 4814 323 4 4821 135 5 2971 275 5 8576 605 6 7061 788 6 6608 336 6 1414 671 6 ...
output:
4445
result:
ok single line: '4445'
Test #13:
score: 0
Accepted
time: 209ms
memory: 16908kb
input:
54756 10000 150207 0 9999 0 1148 773 0 5763 985 0 2835 602 0 977 30 0 9223 600 0 2104 51 0 2094 617 1 4084 55 1 8160 512 1 2837 284 2 3303 473 2 9720 598 2 3700 191 2 9804 546 2 5114 882 2 7947 903 2 4817 499 3 5985 705 3 709 686 3 7579 496 3 172 434 3 7311 760 3 4812 52 4 609 174 5 1269 115 5 4314 ...
output:
3096
result:
ok single line: '3096'
Test #14:
score: 0
Accepted
time: 204ms
memory: 17220kb
input:
54656 10000 150741 0 9999 0 1511 252 0 7148 940 0 486 614 0 4770 773 0 2790 17 0 3626 76 0 9832 174 0 4562 827 1 5855 35 1 9290 513 1 2982 35 1 2854 751 1 6897 316 2 4990 733 2 5224 761 2 3283 21 3 6955 163 3 4823 213 3 2286 385 3 4033 965 4 9836 810 4 9699 309 5 1609 184 5 4014 366 6 6616 824 6 430...
output:
2876
result:
ok single line: '2876'
Test #15:
score: 0
Accepted
time: 0ms
memory: 3604kb
input:
6 5 1 1 0 1 2 3 2 3 10 3 2 12 2 0 7 3 4 20 4 0 30 1 2 0
output:
32
result:
ok single line: '32'
Test #16:
score: 0
Accepted
time: 189ms
memory: 16796kb
input:
54620 10000 148088 0 9999 0 8788 329 0 5514 152 0 8678 225 0 373 846 0 3314 720 0 8746 235 0 7183 822 0 6125 619 1 8172 190 2 4792 153 2 1637 513 2 8863 382 2 5682 160 2 1245 423 3 2635 430 3 7675 950 3 1297 203 3 7691 368 3 2102 619 3 4561 911 4 9702 137 4 3518 713 4 3199 10 5 6043 169 5 5485 427 5...
output:
-1
result:
ok single line: '-1'
Test #17:
score: 0
Accepted
time: 389ms
memory: 26924kb
input:
100499 20000 252177 0 19999 0 4909 501 0 7476 72 0 213 419 0 1345 437 0 15774 245 0 19177 110 0 14978 643 1 3596 825 1 1551 83 1 5153 659 1 19670 367 1 14230 690 1 14114 887 1 4960 258 1 19970 664 2 3014 89 2 3704 551 2 4713 838 2 19776 812 2 2058 634 2 10576 105 2 6594 344 2 17514 686 2 18313 144 3...
output:
5221
result:
ok single line: '5221'
Test #18:
score: 0
Accepted
time: 385ms
memory: 27040kb
input:
100285 20000 253404 0 19999 0 4254 100 0 15222 926 0 12348 85 0 18968 814 0 16722 152 0 10524 675 0 5138 145 0 6237 142 0 2540 29 0 11488 316 1 6385 540 1 18451 118 1 8972 753 1 16713 771 1 5968 409 2 6455 750 2 14274 264 2 14479 678 2 18501 760 2 14550 255 2 440 941 4 8620 550 4 13996 430 4 11503 2...
output:
3508
result:
ok single line: '3508'
Test #19:
score: 0
Accepted
time: 364ms
memory: 26896kb
input:
99992 20000 253335 0 19999 0 8255 809 0 3678 983 0 10202 197 0 8622 393 0 6412 513 0 16316 386 0 3764 735 1 10444 620 1 17083 630 1 11119 466 1 1225 624 1 16144 122 1 15830 989 1 17985 6 1 13278 79 1 2046 181 2 4592 920 2 11084 31 2 9617 194 2 13251 529 2 19471 474 2 2815 545 3 13458 7 3 4253 436 3 ...
output:
4648
result:
ok single line: '4648'
Test #20:
score: 0
Accepted
time: 374ms
memory: 26596kb
input:
99717 20000 247973 0 19999 0 9436 682 0 8559 374 0 19400 453 0 11207 429 0 6056 453 0 6013 179 0 12699 988 0 19103 35 1 15305 25 1 17933 126 1 11215 696 1 19216 1000 1 16966 238 1 80 802 1 10058 496 1 7591 843 1 15526 204 2 19411 813 3 14998 586 3 17342 655 4 501 798 4 19523 977 4 6334 938 5 14088 1...
output:
2710
result:
ok single line: '2710'
Test #21:
score: 0
Accepted
time: 367ms
memory: 26540kb
input:
100090 20000 247340 0 19999 0 14430 821 0 12070 934 0 10224 601 2 5406 669 2 17051 351 2 19716 574 2 15929 494 2 16023 600 3 7632 312 3 7322 276 3 9832 189 3 2065 720 4 898 949 4 13807 865 4 7870 371 4 4133 953 4 11288 718 4 14981 287 4 17165 597 5 7245 485 6 16271 800 6 18484 830 6 13913 664 6 1585...
output:
4198
result:
ok single line: '4198'
Test #22:
score: 0
Accepted
time: 383ms
memory: 27112kb
input:
100333 20000 253847 0 19999 0 4558 679 0 32 669 1 3597 719 1 1059 439 1 18976 206 1 17126 802 1 12710 213 1 6219 8 2 4533 253 2 13974 148 2 10008 702 2 2907 476 2 14689 259 2 15681 773 3 13878 537 3 18752 969 4 17254 804 4 5280 851 4 9723 816 4 9873 195 4 17393 52 4 15740 532 5 9583 966 5 16931 314 ...
output:
4282
result:
ok single line: '4282'
Test #23:
score: 0
Accepted
time: 381ms
memory: 26568kb
input:
99415 20000 247270 0 19999 0 17753 435 0 3769 784 0 14821 77 0 15948 956 0 12628 755 0 6834 759 0 1465 865 0 8841 436 1 2024 797 1 16892 505 1 9941 825 2 6212 117 2 18097 767 2 12725 290 2 12100 282 2 13471 976 2 724 989 2 7368 730 2 7704 264 2 10011 602 3 10292 242 4 18438 76 4 2786 777 4 13198 806...
output:
3652
result:
ok single line: '3652'
Test #24:
score: 0
Accepted
time: 380ms
memory: 26732kb
input:
100086 20000 250032 0 19999 0 8764 438 0 5784 974 1 13571 515 2 19393 158 2 3706 356 3 1834 732 3 17282 589 3 1533 514 3 2863 14 3 9103 608 3 17238 344 3 16470 592 3 16639 641 3 5254 308 3 17414 885 5 811 361 5 12102 4 5 3140 17 5 2367 727 5 18607 440 6 6062 774 6 15731 635 7 16272 53 7 8033 401 7 3...
output:
4384
result:
ok single line: '4384'
Test #25:
score: 0
Accepted
time: 374ms
memory: 26428kb
input:
99662 20000 248395 0 19999 0 10118 469 0 14790 675 2 17863 520 2 19318 409 2 18256 263 2 13319 411 2 19237 664 2 12098 151 2 655 499 3 13943 801 3 13181 51 3 5386 790 3 13107 300 3 3071 120 3 10847 500 3 15094 368 3 16245 968 3 10440 902 3 17586 266 4 14461 275 4 13097 854 4 6205 27 4 18855 767 4 63...
output:
5611
result:
ok single line: '5611'
Test #26:
score: 0
Accepted
time: 0ms
memory: 3648kb
input:
7 5 2 1 0 1 2 3 2 3 10 3 2 12 2 0 7 3 4 20 4 0 30 4 3 3 1 2 0 2 3 2
output:
55
result:
ok single line: '55'
Test #27:
score: 0
Accepted
time: 612ms
memory: 38504kb
input:
150086 30000 377004 0 29999 0 7017 866 0 17935 860 0 25861 553 0 2326 888 0 10317 681 1 17333 263 1 26103 517 1 25852 84 1 20677 545 1 27100 52 1 14519 930 1 26975 459 1 15317 20 2 16898 487 2 6874 120 2 25323 859 2 23144 846 2 19019 315 3 13597 246 4 23206 20 4 7288 975 4 27265 967 4 14904 379 5 13...
output:
3408
result:
ok single line: '3408'
Test #28:
score: 0
Accepted
time: 625ms
memory: 38852kb
input:
150075 30000 379971 0 29999 0 21471 838 0 20323 412 0 21443 362 0 11315 283 0 29832 535 0 3530 511 0 17214 444 0 13373 977 0 14228 254 0 28709 578 1 6606 281 1 17191 840 1 23705 314 1 326 740 1 9305 960 1 23428 903 1 23904 151 1 2538 221 1 8580 33 1 14860 587 2 19222 209 2 26555 470 2 28039 88 2 275...
output:
2761
result:
ok single line: '2761'
Test #29:
score: 0
Accepted
time: 605ms
memory: 38584kb
input:
149963 30000 373755 0 29999 0 5499 956 0 18399 900 0 16446 102 3 12363 607 3 11578 659 3 11777 412 3 8572 275 3 19824 420 4 6808 364 4 22851 414 4 11462 846 4 23846 235 5 14119 85 5 17215 341 5 11373 462 5 13176 526 5 19279 185 5 27159 983 5 16560 221 5 23987 939 6 21917 397 6 1882 667 6 283 984 6 2...
output:
3229
result:
ok single line: '3229'
Test #30:
score: 0
Accepted
time: 600ms
memory: 38524kb
input:
149888 30000 375215 0 29999 0 21239 351 0 8581 738 0 17775 369 1 27168 377 1 28084 786 1 14244 623 1 18644 778 1 1208 222 2 3064 683 2 19744 632 2 12792 662 3 1226 333 3 19228 674 3 29342 131 3 23919 421 3 3502 242 3 6695 181 3 9912 283 3 1308 611 3 18119 510 4 21374 599 4 17161 50 4 19097 52 5 1519...
output:
4846
result:
ok single line: '4846'
Test #31:
score: 0
Accepted
time: 392ms
memory: 30776kb
input:
149852 30000 373545 0 29999 1 28864 590 1 15880 90 1 2104 263 1 2158 599 1 26362 871 1 9557 426 1 22236 973 2 21297 578 2 13493 920 2 25748 185 2 6281 224 2 23862 544 2 8166 691 2 8902 200 2 26616 927 2 13426 956 4 2098 684 4 19445 486 4 25706 108 4 14203 714 4 4985 420 4 21436 653 5 8512 486 5 1149...
output:
-1
result:
ok single line: '-1'
Test #32:
score: 0
Accepted
time: 589ms
memory: 38160kb
input:
149610 30000 371424 0 29999 0 21594 406 0 14642 846 0 27294 803 0 770 169 0 10597 927 0 20942 537 0 22971 468 0 15068 35 0 26190 222 0 15904 767 1 18156 264 2 1484 416 2 18695 561 3 19438 111 3 22176 934 3 1743 78 3 597 747 3 3103 11 3 17278 379 3 8961 134 3 29892 970 4 13574 279 4 21194 37 4 6690 8...
output:
4052
result:
ok single line: '4052'
Test #33:
score: 0
Accepted
time: 606ms
memory: 39204kb
input:
151474 30000 383060 0 29999 0 18089 984 0 14178 594 1 19630 224 1 28841 60 1 2792 439 1 29789 798 2 22049 676 2 5019 538 2 3275 292 2 11063 838 2 19377 164 2 22684 129 3 974 374 3 28491 357 4 27122 837 4 28192 413 4 2663 895 4 22806 785 4 13274 295 4 19018 878 5 339 868 5 667 205 5 25696 580 5 3455 ...
output:
6213
result:
ok single line: '6213'
Test #34:
score: 0
Accepted
time: 602ms
memory: 38400kb
input:
149536 30000 373566 0 29999 0 729 808 0 2056 883 0 19108 560 0 5306 10 0 2300 604 2 4359 480 2 10917 132 2 29369 927 2 20111 487 2 13180 540 2 2749 760 2 21657 232 3 20657 530 3 25722 153 3 5909 468 3 16160 84 3 27183 273 3 25219 820 3 662 48 3 5452 382 4 1063 296 4 18912 565 4 28303 140 4 13061 636...
output:
4296
result:
ok single line: '4296'
Test #35:
score: 0
Accepted
time: 598ms
memory: 38540kb
input:
150291 30000 374286 0 29999 0 178 521 0 1131 106 0 8225 996 0 11487 465 0 11541 774 0 2397 659 0 12282 558 0 27884 335 0 29072 264 2 5266 990 2 19318 470 2 25962 440 2 21030 400 2 14986 750 2 4008 744 2 12469 171 2 10017 838 3 6943 577 3 26773 915 3 4800 976 3 16225 666 3 8576 750 3 13448 952 3 2990...
output:
5054
result:
ok single line: '5054'
Test #36:
score: 0
Accepted
time: 611ms
memory: 38744kb
input:
150597 30000 377534 0 29999 0 20603 93 0 8291 612 0 21907 766 0 2937 316 0 12651 870 0 12540 407 0 132 652 0 28120 506 0 17646 658 0 21454 212 1 23996 643 1 28551 385 1 13108 529 1 5680 338 1 106 772 1 14303 815 1 11290 473 1 4452 152 1 25118 720 1 14800 913 2 1643 36 2 26156 759 2 8526 419 2 26619 ...
output:
2315
result:
ok single line: '2315'
Test #37:
score: 0
Accepted
time: 0ms
memory: 3548kb
input:
7 5 2 1 1 1 2 3 2 3 10 3 2 12 2 0 7 3 4 20 4 0 30 4 3 3 1 2 0 2 3 2
output:
0
result:
ok single line: '0'
Test #38:
score: 0
Accepted
time: 769ms
memory: 45060kb
input:
165113 30000 455900 0 29999 0 15103 975 0 2645 226 0 4732 174 0 9052 353 0 21524 844 0 5194 865 1 9378 218 1 27623 91 1 2190 888 1 21528 815 1 12042 569 2 24855 712 2 339 349 2 25356 334 2 29918 454 2 4894 351 3 6234 816 3 16972 638 3 23107 170 3 11904 909 3 18490 205 4 26133 285 4 29709 86 4 8339 6...
output:
4380
result:
ok single line: '4380'
Test #39:
score: 0
Accepted
time: 0ms
memory: 3540kb
input:
7 6 3 0 5 0 2 3 2 1 7 1 4 8 4 2 12 2 3 10 3 2 12 2 5 10 0 2 1 0 2 5 3 2 5
output:
62
result:
ok single line: '62'
Test #40:
score: 0
Accepted
time: 0ms
memory: 3616kb
input:
10 8 4 0 5 0 2 3 2 1 7 1 4 8 4 2 12 2 3 10 3 2 12 2 5 10 3 6 10 6 7 5 7 3 5 0 2 1 0 2 5 3 2 5 2 3 2
output:
82
result:
ok single line: '82'
Test #41:
score: 0
Accepted
time: 0ms
memory: 3776kb
input:
11 8 4 0 5 0 2 3 2 1 7 1 4 10 4 2 10 2 3 10 3 2 12 2 5 10 3 6 10 6 7 5 7 3 5 6 4 10 0 2 1 0 2 5 3 2 5 2 3 2
output:
53
result:
ok single line: '53'
Test #42:
score: 0
Accepted
time: 0ms
memory: 3844kb
input:
12 8 5 0 5 0 2 3 2 1 7 1 4 10 4 2 10 2 3 10 3 2 12 2 5 10 3 6 10 6 7 5 7 3 5 6 4 10 4 1 0 0 2 1 0 2 5 3 2 5 2 3 2 6 4 2
output:
63
result:
ok single line: '63'
Test #43:
score: 0
Accepted
time: 0ms
memory: 3544kb
input:
11 8 5 0 5 0 2 3 2 1 7 4 2 10 2 3 10 3 2 12 2 5 10 3 6 10 6 7 5 7 3 5 6 4 10 4 1 0 0 2 1 0 2 5 3 2 5 2 3 2 6 4 2
output:
-1
result:
ok single line: '-1'