n个顶点m条边,请求割边

输入格式:

第一行给定三个整数 n,m 。n 个城镇,m 条道路(双向道路)。接下来给出 m 行,每行两个正整数表示这两个城镇之间有边相连。

输出格式:

一个整数,有几条关键道路。

样例 1 :

输入:
6 6 1 3 1 4 2 3 2 4 2 5 5 6
输出:
2
说明:
2-5和5-6是桥

 1 #include <cstdio>
 2 #include <vector>
 3 #include <cstring>
 4 
 5 
 6 using namespace std;
 7 
 8 
 9 const int max_n = 1e5 + 10;
10 int n,m;
11 int num[max_n],low[max_n];
12 int time_index,a,b;
13 vector<int> g[max_n];
14 int ans;
15 
16 
17 void dfs(int cur,int fa)
18 {
19     ++time_index;
20     num[cur]=time_index;
21     low[cur]=time_index;
22 
23     for(int i=0;i<g[cur].size();++i)
24     {
25         int v=g[cur][i];
26         if(num[v]==0)
27         {
28             dfs(v,cur);
29             low[cur]=min(low[cur],low[v]);
30             if(low[v]>num[cur])
31             {
32                 ++ans;
33             }
34         }
35         else if(fa!=v)
36         {
37             low[cur]=min(low[cur],num[v]);
38         }
39     }
40 }
41 
42 void solve()
43 {
44     ans=0;
45     time_index=0;
46     memset(num,0,sizeof(num));
47 
48     dfs(1,1);
49 
50     printf("%d",ans);
51 }
52 
53 
54 int main()
55 {
56     scanf("%d %d",&n,&m);
57     for(int i=0;i<m;++i)
58     {
59         scanf("%d %d",&a,&b);
60         g[a].push_back(b);
61         g[b].push_back(a);
62     }
63 
64     solve();
65 
66     return 0;
67 }

 

posted on 2020-01-26 14:49  带你AK,带你飞  阅读(178)  评论(0编辑  收藏  举报