码迷,mamicode.com
首页 > 其他好文 > 详细

hdu 4738 Caocao's Bridges(桥的最小权值+去重)

时间:2015-08-17 10:08:10      阅读:107      评论:0      收藏:0      [点我收藏+]

标签:

http://acm.hdu.edu.cn/showproblem.php?pid=4738

题目大意:曹操有一些岛屿被桥连接,每座都有士兵把守,周瑜想把这些岛屿分成两部分,但他只能炸毁一条桥,问最少需要派几个士兵去;如果不能完成输出-1

1:如果这些岛屿不连通,则不需要派人前去

2:如果桥的守卫是0的话也得派一人去炸毁

3:如果不能完成输出-1

4:输出最少需派的人数

技术分享
#include<stdio.h>
#include<string.h>
#include<math.h>
#include<queue>
#include<algorithm>
using namespace std;
#define N 1100
#define INF 0xfffffff

int dfn[N], low[N], head[N], f[N];
int Time, m, n, Min, cnt;
struct Edge
{
    int next, u, v, c;
} edge[N * N];
void Init()
{
    memset(head, -1, sizeof(head));
    memset(dfn, 0, sizeof(dfn));
    memset(low, 0, sizeof(low));
    memset(f, 0, sizeof(f));
    Time = cnt = 0;
}

void AddEdge(int u, int v, int c)
{
    edge[cnt].u = u;
    edge[cnt].v = v;
    edge[cnt].c = c;
    edge[cnt].next = head[u];
    head[u] = cnt++;
}

void Tarjan(int u, int fa)
{
    int i, v, flag = 0;
    low[u] = dfn[u] = ++Time;
    f[u] = fa;
    for(i = head[u] ; i != -1 ; i = edge[i].next)
    {
        v = edge[i].v;
        if(v == fa && !flag)
        {
            flag = 1;
            continue;
        }//去重边,如果有重边则跳过
        if(!dfn[v])
        {
            Tarjan(v, u);
            low[u] = min(low[u], low[v]);
            if(dfn[u] < low[v])
                Min = min(Min, edge[i].c);
        }
        else
            low[u] = min(low[u], dfn[v]);
    }
}

int main()
{
    int i, u, v, c, k;
    while(scanf("%d%d", &m, &n), m + n)
    {
        Init();
        k = 0;
        while(n--)
        {
            scanf("%d%d%d", &u, &v, &c);
            AddEdge(u, v, c);
            AddEdge(v, u, c);
        }
        Min = INF;
        for(i = 1 ; i <= m ; i++)
        {
            if(!dfn[i])
            {
                Tarjan(i, -1);
                k++;
            }
        }
        if(k > 1)
        {
            printf("0\n");
            continue;
        }//1
        if(Min == 0)
            printf("1\n");//2
        else if(Min == INF)
            printf("-1\n");//3
        else
            printf("%d\n", Min);//4
    }
    return 0;
}
View Code

 

hdu 4738 Caocao's Bridges(桥的最小权值+去重)

标签:

原文地址:http://www.cnblogs.com/qq2424260747/p/4735691.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!