QOJ.ac
QOJ
ID | 题目 | 提交者 | 结果 | 用时 | 内存 | 语言 | 文件大小 | 提交时间 | 测评时间 |
---|---|---|---|---|---|---|---|---|---|
#475915 | #995. 桥 | modinte# | WA | 57ms | 14084kb | C++14 | 854b | 2024-07-13 17:08:19 | 2024-07-13 17:08:19 |
Judging History
answer
#include <bits/stdc++.h>
const int N = 1e5 + 5, M = 1e6 + 5;
int n, m, tot = 1, head[N], nxt[M], ver[M], dfc, dfn[N], low[N];
bool bri[N];
void adde(int u, int v) {
nxt[++tot] = head[u], head[u] = tot, ver[tot] = v;
}
void Tarjan(int u, int ban) {
dfn[u] = low[u] = ++dfc;
for (int i = head[u]; i; i = nxt[i]) {
int v = ver[i];
if (!dfn[v]) {
Tarjan(v, i ^ 1), low[u] = std::min(low[u], low[v]);
if (low[v] > dfn[u]) bri[i] = bri[i ^ 1] = true;
}
else if (i != ban) low[u] = std::min(low[u], dfn[v]);
}
}
int main() {
scanf("%d%d", &n, &m);
for (int i = 1, u, v; i <= m; ++i)
scanf("%d%d", &u, &v), adde(u, v), adde(v, u);
for (int i = 1; i <= n; ++i) if (!dfn[i]) Tarjan(i, 0);
for (int i = 2; i < tot; i += 2)
if (bri[i]) printf("%d %d\n", ver[i ^ 1], ver[i]);
return 0;
}
详细
Test #1:
score: 0
Wrong Answer
time: 57ms
memory: 14084kb
input:
24942 387166 12556 21443 22404 16376 11073 24296 1535 11968 23745 2818 5073 12731 22550 14761 24118 12008 22695 18979 15118 13639 2080 8721 692 22578 22581 15267 9278 4127 7457 21674 17693 23448 10949 23429 9700 6009 14140 5064 7742 15164 17336 1662 18903 9760 17645 19575 6540 11942 11 4937 15282 10...
output:
3580 22348 22782 2580 218 11638 14705 11131 6588 16803 14572 14850 24073 16481 309 2574 3687 15673 17358 14470 12142 2461 8613 14871 3188 2066 659 17955 5729 24387 5010 23733 2027 14085 7075 16754 5607 5809 20166 22682 1593 10111 15404 13366 20664 13964 7620 1895 23862 8571 10205 16257 18025 11125 2...
result:
wrong output format Extra information in the output file