QOJ.ac
QOJ
ID | 题目 | 提交者 | 结果 | 用时 | 内存 | 语言 | 文件大小 | 提交时间 | 测评时间 |
---|---|---|---|---|---|---|---|---|---|
#566502 | #9310. Permutation Counting 4 | hshhh | WA | 75ms | 9796kb | C++14 | 1.0kb | 2024-09-16 00:17:03 | 2024-09-16 00:17:05 |
Judging History
answer
#include <bits/stdc++.h>
using namespace std;
using i64 = long long;
const int INF = 0x3f3f3f3f;
const i64 mod = 1e9 + 7;
const int N = 1000005;
i64 n;
int head[N], nxt[2*N], to[2*N], cnt;
void add(int u, int v) {
nxt[++cnt] = head[u];
head[u] = cnt;
to[cnt] = v;
}
bool vis[N], ok;
void dfs(int cur, int id) {
vis[cur] = 1;
for(int i = head[cur]; i; i = nxt[i]) {
if(ok == 0) return;
if((i^id) == 1) continue;
int v = to[i];
if(vis[v]) {
ok = 0;
return;
}
dfs(v, i);
}
}
void solve() {
cin >> n;
ok = 1;
cnt = 1;
for(int i = 1; i <= n+1; ++i) {
vis[i] = 0;
head[i] = 0;
}
for(int i = 1; i <= n; ++i) {
int u, v;
cin >> u >> v;
add(u, v+1);
add(v+1, u);
}
dfs(1, 0);
cout << (ok ? 1 : 0) << '\n';
};
int main() {
ios::sync_with_stdio(false), cin.tie(0);
int t;
cin >>t;
while(t--) {
solve();
}
return 0;
}
详细
Test #1:
score: 100
Accepted
time: 2ms
memory: 9772kb
input:
4 5 1 2 1 5 1 2 1 2 2 2 5 1 1 2 4 2 3 5 5 3 4 5 3 5 1 2 3 4 3 5 3 3 5 1 5 1 4 4 5 5 5 1 2
output:
0 1 0 0
result:
ok 4 tokens
Test #2:
score: -100
Wrong Answer
time: 75ms
memory: 9796kb
input:
66725 14 7 7 4 6 7 8 8 13 2 13 6 13 6 10 14 14 1 10 9 11 7 9 3 8 4 12 5 12 12 2 6 3 6 7 11 2 5 1 1 6 12 8 12 2 3 7 9 7 8 1 10 1 4 10 4 8 4 4 6 10 9 10 2 3 2 7 1 3 3 4 2 2 3 10 20 3 12 10 14 19 20 19 20 1 9 7 9 13 16 17 17 16 18 2 11 5 19 6 17 11 17 3 6 3 11 7 20 8 17 3 18 10 15 9 20 16 5 10 2 10 2 1...
output:
1 1 0 0 1 0 1 1 0 1 1 1 0 0 0 1 1 1 1 0 0 1 1 1 1 1 0 1 0 0 1 0 1 0 1 1 1 1 1 0 1 1 1 1 1 1 1 1 1 1 0 1 1 0 1 0 0 1 0 1 0 1 1 0 1 1 1 0 1 0 1 1 0 0 1 1 1 1 1 1 1 1 1 0 1 1 1 1 1 1 1 1 1 0 0 1 1 0 0 1 1 0 1 1 1 1 1 1 1 0 0 1 1 1 0 0 1 1 0 0 1 0 1 0 1 0 1 0 0 0 0 1 1 0 0 1 1 1 1 1 0 0 1 1 0 0 1 0 1 1 ...
result:
wrong answer 12th words differ - expected: '0', found: '1'