zoukankan      html  css  js  c++  java
  • 【AtCoder ABC 075 C】Bridge

    【链接】 我是链接,点我呀:)
    【题意】

    让你求出桥的个数

    【题解】

    删掉这条边,然后看看1能不能到达其他所有的点就可以了

    【代码】

        #include <bits/stdc++.h>
        using namespace std;
         
        const int M = 50;
         
        int n, m,g[M+10][M+10];
        pair<int, int> a[M+10];
        bool bo[M + 10];
         
        void dfs(int x)
        {
        	if (bo[x]) return;
        	bo[x] = true;
        	for (int i = 1;i <= n;i++)
        		if (i!=x && g[x][i])
        			dfs(i);
        }
         
        int main()
        {
        	//freopen("F:\rush.txt", "r", stdin);
        	scanf("%d%d", &n, &m);
        	for (int i = 1; i <= m; i++)
        	{
        		int x, y;
        		scanf("%d%d", &x, &y);
        		g[x][y] = g[y][x] = 1;
        		a[i] = make_pair(x, y);
        	}
         
        	int ans = 0;
        	for (int i = 1; i <= m; i++)
        	{
        		g[a[i].first][a[i].second] = 0;
        		g[a[i].second][a[i].first] = 0;
        		for (int j = 1; j <= n; j++) bo[j] = 0;
        		dfs(1);
        		int ok = false;
        		for (int j = 1; j <= n; j++)
        			if (bo[j] == 0)
        				ok = 1;
        		ans += ok;
        		g[a[i].first][a[i].second] = 1;
        		g[a[i].second][a[i].first] = 1;
        	}
        	printf("%d
    ", ans);
        	return 0;
        }
    
  • 相关阅读:
    iOS缓存
    哈希表
    查找
    基数排序
    归并排序
    快速排序
    redis 的高并发的理解
    springboot的理解
    使用maven命令安装jar包到本地仓库
    linux Centos7 安装docker步骤
  • 原文地址:https://www.cnblogs.com/AWCXV/p/7669808.html
Copyright © 2011-2022 走看看