QOJ.ac
QOJ
ID | 题目 | 提交者 | 结果 | 用时 | 内存 | 语言 | 文件大小 | 提交时间 | 测评时间 |
---|---|---|---|---|---|---|---|---|---|
#304053 | #8011. Institute | ucup-team087# | AC ✓ | 91ms | 35212kb | C++14 | 3.8kb | 2024-01-13 13:24:56 | 2024-01-13 13:24:56 |
Judging History
answer
#include <cassert>
#include <cmath>
#include <cstdint>
#include <cstdio>
#include <cstdlib>
#include <cstring>
#include <algorithm>
#include <bitset>
#include <complex>
#include <deque>
#include <functional>
#include <iostream>
#include <limits>
#include <map>
#include <numeric>
#include <queue>
#include <random>
#include <set>
#include <sstream>
#include <string>
#include <unordered_map>
#include <unordered_set>
#include <utility>
#include <vector>
using namespace std;
using Int = long long;
template <class T1, class T2> ostream &operator<<(ostream &os, const pair<T1, T2> &a) { return os << "(" << a.first << ", " << a.second << ")"; };
template <class T> ostream &operator<<(ostream &os, const vector<T> &as) { const int sz = as.size(); os << "["; for (int i = 0; i < sz; ++i) { if (i >= 256) { os << ", ..."; break; } if (i > 0) { os << ", "; } os << as[i]; } return os << "]"; }
template <class T> void pv(T a, T b) { for (T i = a; i != b; ++i) cerr << *i << " "; cerr << endl; }
template <class T> bool chmin(T &t, const T &f) { if (t > f) { t = f; return true; } return false; }
template <class T> bool chmax(T &t, const T &f) { if (t < f) { t = f; return true; } return false; }
#define COLOR(s) ("\x1b[" s "m")
struct Scc {
int n;
vector<int> as, bs;
vector<int> ptr, zu, us;
int l;
vector<int> ids;
int operator[](int u) const { return ids[u]; }
explicit Scc(int n_) : n(n_), as(), bs(), l(-1) {}
void ae(int u, int v) {
assert(0 <= u); assert(u < n);
assert(0 <= v); assert(v < n);
as.push_back(u);
bs.push_back(v);
}
void dfs0(int u) {
if (!ids[u]) {
ids[u] = -1;
for (int i = ptr[u]; i < ptr[u + 1]; ++i) dfs0(zu[i]);
us.push_back(u);
}
}
void dfs1(int u) {
if (!~ids[u]) {
ids[u] = l;
for (int i = ptr[u]; i < ptr[u + 1]; ++i) dfs1(zu[i]);
}
}
void run() {
const int m = as.size();
ptr.resize(n + 2);
zu.resize(m);
for (int u = 0; u < n + 2; ++u) ptr[u] = 0;
for (int i = 0; i < m; ++i) ++ptr[as[i] + 2];
for (int u = 2; u < n + 1; ++u) ptr[u + 1] += ptr[u];
for (int i = 0; i < m; ++i) zu[ptr[as[i] + 1]++] = bs[i];
ids.assign(n, 0);
us.clear();
for (int u = 0; u < n; ++u) dfs0(u);
for (int u = 0; u < n + 2; ++u) ptr[u] = 0;
for (int i = 0; i < m; ++i) ++ptr[bs[i] + 2];
for (int u = 2; u < n + 1; ++u) ptr[u + 1] += ptr[u];
for (int i = 0; i < m; ++i) zu[ptr[bs[i] + 1]++] = as[i];
l = 0;
for (int j = n; --j >= 0; ) if (!~ids[us[j]]) { dfs1(us[j]); ++l; }
}
vector<vector<int>> group() const {
assert(~l);
vector<vector<int>> uss(l);
for (int u = 0; u < n; ++u) uss[ids[u]].push_back(u);
return uss;
}
};
int N, M;
vector<int> A, B, C;
vector<vector<int>> graph[3];
vector<int> vis;
void dfs(int u) {
if (!vis[u]) {
vis[u] = 1;
for (int c = 1; c <= 2; ++c) {
for (const int v : graph[c][u]) {
dfs(v);
}
}
}
}
int main() {
for (; ~scanf("%d%d", &N, &M); ) {
A.resize(M);
B.resize(M);
C.resize(M);
for (int i = 0; i < M; ++i) {
scanf("%d%d%d", &A[i], &B[i], &C[i]);
--A[i];
--B[i];
}
Scc scc2(N);
for (int i = 0; i < M; ++i) if (C[i] == 2) {
scc2.ae(A[i], B[i]);
}
scc2.run();
graph[1].assign(N, {});
graph[2].assign(N, {});
for (int i = 0; i < M; ++i) {
graph[C[i]][A[i]].push_back(B[i]);
}
vis.assign(N, 0);
dfs(0);
bool ans = false;
for (int u = 0; u < N; ++u) if (vis[u]) {
for (const int v : graph[2][u]) {
if (scc2[u] != scc2[v]) {
// cerr<<"ans "<<u<<" "<<v<<endl;
ans = true;
}
}
}
puts(ans ? "Yes" : "No");
}
return 0;
}
这程序好像有点Bug,我给组数据试试?
详细
Test #1:
score: 100
Accepted
time: 0ms
memory: 3908kb
input:
3 4 1 2 1 2 3 2 3 2 1 3 1 2
output:
Yes
result:
ok answer is YES
Test #2:
score: 0
Accepted
time: 0ms
memory: 3652kb
input:
6 8 1 2 1 2 3 2 3 2 2 3 4 1 4 1 2 1 5 2 5 4 2 6 1 2
output:
No
result:
ok answer is NO
Test #3:
score: 0
Accepted
time: 0ms
memory: 3736kb
input:
1000 1000 141 466 1 634 659 1 179 96 2 445 344 2 993 974 1 310 114 2 32 333 1 758 832 1 834 1 1 874 825 2 480 61 2 765 100 2 804 616 1 496 545 1 786 261 2 899 263 1 962 237 2 766 807 1 561 583 1 35 425 1 201 291 1 6 142 1 61 386 2 785 861 2 386 986 2 288 769 2 850 209 1 660 259 2 258 143 2 646 715 2...
output:
Yes
result:
ok answer is YES
Test #4:
score: 0
Accepted
time: 1ms
memory: 3840kb
input:
1000 3000 719 279 2 857 23 1 984 625 2 904 509 2 892 456 2 589 195 2 718 932 2 608 363 1 474 672 1 217 993 2 165 895 2 727 329 2 932 404 2 952 146 2 201 272 2 412 895 2 228 267 2 396 365 2 813 794 2 259 250 1 968 764 2 100 76 2 924 665 2 981 931 2 292 975 2 903 649 2 793 101 2 54 703 1 853 58 2 356 ...
output:
Yes
result:
ok answer is YES
Test #5:
score: 0
Accepted
time: 1ms
memory: 3900kb
input:
1000 3000 686 470 2 132 418 2 775 962 2 814 8 2 450 767 2 580 243 2 742 534 2 508 304 2 396 513 2 731 385 2 499 309 2 144 150 2 111 209 2 340 189 1 219 755 2 511 655 2 428 941 2 165 707 2 253 619 2 140 766 2 999 132 2 415 101 2 887 192 2 598 262 2 312 675 1 97 527 2 407 179 2 11 154 1 107 996 2 586 ...
output:
No
result:
ok answer is NO
Test #6:
score: 0
Accepted
time: 0ms
memory: 4188kb
input:
10000 10000 1496 8533 1 6761 8802 2 3147 8733 2 7074 899 1 4191 9520 2 2576 1464 1 8600 116 2 72 5894 1 1605 6769 1 344 2583 2 9951 8053 2 2663 1396 1 3172 7307 1 8490 8085 2 6623 7814 2 680 4471 2 4906 3810 1 5952 8860 1 9670 3644 2 7993 6329 2 4666 1119 2 3115 3676 2 4506 2979 2 1451 2540 2 5002 9...
output:
No
result:
ok answer is NO
Test #7:
score: 0
Accepted
time: 7ms
memory: 5188kb
input:
10000 30000 8022 6065 2 8185 3186 1 9803 6371 1 4947 1271 2 926 9103 2 8367 1328 2 6314 1627 2 203 4366 2 9992 1021 2 5092 9288 1 7412 6217 2 4569 5568 2 7064 6970 2 4363 1581 2 772 6243 2 2571 4950 2 5821 8367 1 7985 5827 2 2064 4754 2 900 605 1 2083 3137 2 7852 1194 2 4679 6769 2 9389 6753 2 2980 ...
output:
Yes
result:
ok answer is YES
Test #8:
score: 0
Accepted
time: 4ms
memory: 5172kb
input:
10000 30000 6708 6418 2 120 3115 2 1647 6703 1 86 1015 2 5041 8379 2 1926 2108 2 1030 4579 2 1129 4269 2 7245 1725 2 9605 679 2 2903 1467 2 233 9636 2 8796 738 2 1535 7292 2 6010 1476 2 9300 4436 2 7465 5575 2 4508 1537 2 4352 9653 2 6646 4932 2 6069 2244 2 8361 4603 2 3566 9063 2 6836 5173 2 2194 3...
output:
No
result:
ok answer is NO
Test #9:
score: 0
Accepted
time: 80ms
memory: 34808kb
input:
300000 300000 94246 283175 1 83027 278500 2 265400 62933 2 174359 187478 2 175633 104311 1 279454 288119 1 143302 18555 1 258847 186237 1 207649 136874 1 182701 13491 1 261536 220848 1 206849 280776 2 60075 295 2 242474 256281 2 293852 21768 2 36248 183324 2 145642 275253 1 9956 11629 2 25110 265376...
output:
No
result:
ok answer is NO
Test #10:
score: 0
Accepted
time: 91ms
memory: 35212kb
input:
300000 300000 2755 160424 2 156539 216928 2 41979 111770 2 94794 284215 2 88031 115072 1 55508 189463 2 142066 99620 2 68946 262040 2 234053 268389 2 177636 61056 2 216374 97188 1 189152 250356 2 128748 241240 2 260431 9729 2 165046 99023 2 106219 190566 1 228664 97992 2 80967 18715 2 118443 178799 ...
output:
Yes
result:
ok answer is YES
Test #11:
score: 0
Accepted
time: 91ms
memory: 34936kb
input:
300000 300000 201841 218620 2 25571 244075 2 148023 244788 1 12618 187161 2 123903 157292 2 140719 283744 2 48104 57739 2 94140 217701 2 260292 235506 2 244136 52545 2 113842 82619 2 284670 286686 2 102210 172102 2 93693 135210 2 169155 31435 1 121590 294638 2 231463 149656 2 132100 245329 2 78578 2...
output:
No
result:
ok answer is NO
Test #12:
score: 0
Accepted
time: 43ms
memory: 11696kb
input:
10000 300000 8794 9638 2 4124 3198 2 3709 4571 1 7094 2604 2 9787 8634 1 9259 7034 1 805 8951 1 523 1299 2 4067 2337 1 3442 8604 1 990 229 2 5669 9222 2 794 5188 2 7066 4135 1 2328 6841 2 5400 3669 2 8572 6053 2 5808 755 2 1035 9229 2 4699 4976 1 5592 6836 2 3316 5324 1 911 8988 1 6872 3245 2 1266 1...
output:
No
result:
ok answer is NO
Test #13:
score: 0
Accepted
time: 81ms
memory: 28852kb
input:
200000 300000 51429 85416 2 35500 102166 2 77261 111280 2 109595 198771 2 52752 98485 2 123959 146471 1 71558 134628 2 53580 97704 2 41770 26184 2 38726 42080 2 32420 161261 1 93622 14014 2 62442 37971 2 97434 174665 2 35402 17953 2 32481 189105 2 133381 197488 2 59630 152080 2 145316 134738 2 15637...
output:
Yes
result:
ok answer is YES
Test #14:
score: 0
Accepted
time: 90ms
memory: 28908kb
input:
200000 300000 100604 79567 2 78619 82912 2 160923 6515 2 111511 22849 2 191823 122510 2 184746 42969 1 367 87329 2 12385 186721 2 22322 89968 2 30296 23410 2 55379 95908 2 78731 185005 2 16026 95076 2 117553 81021 2 17586 162896 2 112457 64630 2 98272 194597 2 94737 47348 2 182434 141187 2 48901 148...
output:
No
result:
ok answer is NO
Test #15:
score: 0
Accepted
time: 84ms
memory: 21992kb
input:
100000 300000 60010 76924 2 98779 52066 2 29705 3673 2 19807 92766 2 89092 55572 2 57798 98074 2 49433 4252 2 9568 11858 2 6068 37755 2 42537 69332 2 34120 95829 2 70957 69524 1 6979 42493 2 18708 80499 2 23615 10086 1 54682 14663 2 66240 6913 1 96259 63852 2 33994 20136 2 50051 79458 2 59557 23910 ...
output:
Yes
result:
ok answer is YES
Test #16:
score: 0
Accepted
time: 70ms
memory: 21952kb
input:
100000 300000 31467 31057 2 53376 30862 2 34548 19018 1 49459 40636 2 24713 26389 2 72031 39008 2 88386 42964 2 6089 36050 2 95525 7354 2 2150 65839 2 23017 48586 2 96644 53330 1 34717 92329 2 60439 23051 2 93738 40918 2 14792 19952 2 47044 31402 2 50447 82391 2 39716 49649 2 53032 32891 1 21843 227...
output:
No
result:
ok answer is NO
Test #17:
score: 0
Accepted
time: 63ms
memory: 15908kb
input:
50000 300000 13657 42151 1 4207 48263 2 19913 14856 1 20252 19946 1 36552 16773 2 15641 47894 1 31929 33862 1 37186 35146 1 26141 19435 1 13344 16689 1 40537 30282 1 44007 12832 2 34199 4971 2 9613 32152 1 22680 7733 1 22821 37016 1 28192 6124 2 20231 20606 2 31231 11050 1 29171 1156 2 10913 10822 2...
output:
Yes
result:
ok answer is YES
Test #18:
score: 0
Accepted
time: 67ms
memory: 16252kb
input:
50000 300000 27901 2832 1 36611 18040 1 11569 29790 1 18772 5119 1 7295 20713 2 34886 41675 1 25208 25186 2 16871 28421 1 16342 25825 1 45452 6926 1 19333 47812 1 49794 31792 2 47593 29029 1 28847 13670 2 10893 34216 2 38904 38242 1 20662 21579 1 39456 43904 2 10339 35210 1 28253 11494 2 22 12016 2 ...
output:
No
result:
ok answer is NO
Test #19:
score: 0
Accepted
time: 38ms
memory: 12716kb
input:
25000 300000 15694 6658 1 12187 18447 1 7540 10018 2 6657 5485 1 21747 711 1 12141 9379 1 21107 3608 1 2289 12866 1 23634 21695 2 19657 17685 2 7651 7593 1 14284 17908 1 7629 9649 1 6823 23485 1 534 24307 2 22109 6259 1 21590 6443 2 22852 13772 1 6668 21394 1 11103 4709 1 13738 22004 2 1428 11491 1 ...
output:
Yes
result:
ok answer is YES
Test #20:
score: 0
Accepted
time: 54ms
memory: 12896kb
input:
25000 300000 20441 13493 1 362 263 1 2835 1312 1 22325 18409 1 4902 3889 1 11908 10885 2 20159 19508 1 22897 21371 1 803 24842 1 15205 19941 1 1454 20196 2 24937 1426 1 7432 16934 1 2006 12538 1 14316 17932 1 10790 1834 1 142 19649 2 3390 22164 2 14482 11138 1 24265 21337 1 16629 20993 1 14448 23824...
output:
No
result:
ok answer is NO
Test #21:
score: 0
Accepted
time: 42ms
memory: 25972kb
input:
200000 299998 1 2 1 1 3 1 3 2 2 1 4 1 4 2 2 1 5 1 5 2 2 1 6 1 6 2 2 1 7 1 7 2 2 1 8 1 8 2 2 1 9 1 9 2 2 1 10 1 10 2 2 1 11 1 11 2 2 1 12 1 12 2 2 1 13 1 13 2 2 1 14 1 14 2 2 1 15 1 15 2 2 1 16 1 16 2 2 1 17 1 17 2 2 1 18 1 18 2 2 1 19 1 19 2 2 1 20 1 20 2 2 1 21 1 21 2 2 1 22 1 22 2 2 1 23 1 23 2 2 ...
output:
Yes
result:
ok answer is YES
Extra Test:
score: 0
Extra Test Passed