QOJ.ac

QOJ

ID题目提交者结果用时内存语言文件大小提交时间测评时间
#475915#995. 桥modinte#WA 57ms14084kbC++14854b2024-07-13 17:08:192024-07-13 17:08:19

Judging History

你现在查看的是最新测评结果

  • [2024-07-13 17:08:19]
  • 评测
  • 测评结果:WA
  • 用时:57ms
  • 内存:14084kb
  • [2024-07-13 17:08:19]
  • 提交

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