刚拿到这道题时挺有思路,无奈平日里只敲过找割顶的代码,判桥的代码当时自己也没仔细敲。

当时一把泪啊,忽然感觉自己的图论才只是刚搞了个起步啊。。

题目有神坑。    就是先判是否连通,不连通直接输出0;

还有一个比较坑的是有重边的情况,那这样就有重边的两点之间就不可能存在桥。

再就是桥上无士兵把守也要派一个人去炸。

。。。

#include <iostream>
#include <cstdio>
#include <cstring>
#include <vector>
#include <algorithm>
using namespace std; const int maxn = 1500;
int dfs_clock, current_clock, ans, current_cc;
int adj[maxn][maxn], iscut[maxn], vis[maxn], pre[maxn], low[maxn];
vector<int> G[maxn];
int n, m, a, b, c, INF = 10000000; void dfs(int u)
{
vis[u] = 1;
//PREVISIT(u); 访问u之前的操作
for(int i = 0; i < G[u].size(); i++)
{
int v = G[u][i];
if(!vis[v]) dfs(v);
}
//POSTVISIT(u); 访问结点u之后的操作
} void find_cc() //给连通分量标号
{
current_cc = 0;
memset(vis, 0, sizeof(vis));
for(int u = 1; u <= n; u++) if(!vis[u])
{
current_cc++;
dfs(u);
}
} int dfs_bridge(int u,int fa) //u在dfs树中的父结点是fa
{
int lowu = pre[u] = ++dfs_clock;
int child = 0; //子结点数目
for(int i = 0; i < G[u].size(); i++)
{
int v = G[u][i];
if(!pre[v]) //没有访问过v
{
child++;
int lowv = dfs_bridge(v, u);
lowu = min(lowu, lowv);
if(lowv >= pre[u])
{
iscut[u] = true; //割点判断
if(lowv > pre[u] && adj[u][v] != -2) //桥的判断可以相应灵活处理
ans = min(ans, adj[u][v]);
}
}
else if(pre[v] < pre[u] && v != fa)
lowu = min(lowu, pre[v]); //用反向边更新u的low函数
}
if(fa < 0 && child == 1)
{
// 但是不用加是否单独判桥的判断?
iscut[u] = 0; //应该是避免单结点判桥、割顶的情况吧
}
low[u] = lowu;
return lowu;
} void init()
{
memset(pre, 0, sizeof(pre));
memset(iscut, 0, sizeof(iscut));
memset(adj, -1 ,sizeof(adj));
for(int i = 0; i <= n; i++)
G[i].clear();
} int main()
{
while(scanf("%d%d",&n, &m) != EOF)
{
if(!n && !m) break;
init();
while(m--)
{
scanf("%d%d%d", &a, &b, &c);
if(adj[a][b] == -1)
{
G[a].push_back(b);
G[b].push_back(a);
adj[a][b] = c;
adj[b][a] = c;
}
else // 两点之间有两条边肯定不可能是桥
{
adj[a][b] = -2;
adj[b][a] = -2;
}
} ans = INF;
dfs(1); find_cc();
//printf("~%d\n",current_cc);
if(current_cc >= 2) { printf("0\n"); continue;}
else dfs_bridge(1, -1);
if(ans == 0) printf("1\n");
else if(ans == INF ) printf("-1\n");
else printf("%d\n", ans);
}
return 0;
}

HDU4738【杭州网赛、判桥】的更多相关文章

  1. 2013杭州网赛 1001 hdu 4738 Caocao's Bridges(双连通分量割边/桥)

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=4738 题意:有n座岛和m条桥,每条桥上有w个兵守着,现在要派不少于守桥的士兵数的人去炸桥,只能炸一条桥 ...

  2. 杭州网赛 two rabbits (hdu 4745)

    算法很简单,问题是,怎么证明,答案是回文序列. 设a,b走的序列按顺时针是: a1 , a2 , a3 , ... , ak b1 , b2 , b3 , ... , bk 考虑端点的2种情况: 1. ...

  3. hdu4740【杭州网赛、模拟、有点搜索?】

    当时看了这题就感觉so easy...  本来不想写的,后来感觉是不是可以练一下搜索水平.. 比赛时有人过了就没写.       比赛完了写一下. 实现还不是那么顺利,  囧 本来自己以为这题能练下搜 ...

  4. ZOJ Bizarre Routine 2013杭州网赛B题

    题目意思: 给定n, expect, a, b 要求你构造一组array[],存放一个1..n的排列,使的下面的程序能输出YES 题目所示代码: bool less_than(x, y) { T++; ...

  5. HDU 4746 HDOJ Mophues 2013杭州网赛I题

    比赛的时候就预感到这题能出,但是会耗时比较多.结果最后是出了,但是有更简单的题没出. 是不是错误的决策呢?谁知道呢 题目意思: 定义f(x) = x分解质因数出来的因子个数 如 x = p0 * p0 ...

  6. HDU 4738 Caocao's Bridges (2013杭州网络赛1001题,连通图,求桥)

    Caocao's Bridges Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others) ...

  7. 2013杭州现场赛B题-Rabbit Kingdom

    杭州现场赛的题.BFS+DFS #include <iostream> #include<cstdio> #include<cstring> #define inf ...

  8. HDU 4745 Two Rabbits (2013杭州网络赛1008,最长回文子串)

    Two Rabbits Time Limit: 10000/5000 MS (Java/Others)    Memory Limit: 65535/65535 K (Java/Others)Tota ...

  9. HDU 4747 Mex (2013杭州网络赛1010题,线段树)

    Mex Time Limit: 15000/5000 MS (Java/Others)    Memory Limit: 65535/65535 K (Java/Others)Total Submis ...

随机推荐

  1. python核心编程-第四章-个人笔记

    1.所有的python对象都拥有三个特性: ①身份:每个对象都有唯一的身份标识自己,可用内建函数id()来得到.基本不会用到,不用太关心 >>> a = 2 >>> ...

  2. mvc学习总结-使用Ninject和CodeFirst

    1.Ninject用来解耦程序:即对接口编程,而不是对实现类编程:理解:BLL对IDAL编程,对应的是调用多种数据实现的DAL,DAL可以是SqlServer的,可以是Oracle,或其他数据媒介: ...

  3. Java application 性能分析分享

    性能分析的主要方式 监视:监视是一种用来查看应用程序运行时行为的一般方法.通常会有多个视图(View)分别实时地显示 CPU 使用情况.内存使用情况.线程状态以及其他一些有用的信息,以便用户能很快地发 ...

  4. html5 web worker

    A web worker is a JavaScript running in the background, without affecting the performance of the pag ...

  5. C语言的本质(26)——C标准库之数值字符串转换

    C语言提供了几个标准库函数,可以将任意类型(整型.长整型.浮点型等)的数字转换为字符串. #include <stdlib.h> int atoi(const char *nptr); a ...

  6. Linux进程间通信——信号集函数

    一.什么是信号 用过Windows的我们都知道,当我们无法正常结束一个程序时,可以用任务管理器强制结束这个进程,但这其实是怎么实现的呢?同样的功能在Linux上是通过生成信号和捕获信号来实现的,运行中 ...

  7. OpenSSL win 下报错 OPENSSL_Uplink(58D46000,08): no OPENSSL_Applink

    python 中使用 M2Crypto 想读写文件时总是报: OPENSSL_Uplink(58D46000,08): no OPENSSL_Applink windows 平台下使用 openssl ...

  8. FPGA的SPI从机模块实现

    一. SPI总线协议         SPI(Serial Peripheral Interface)接口,中文为串行外设接口.它只需要3根线或4根线即可完成通信工作(这里讨论4根线的情况).     ...

  9. 【刷题 Python Tip】题目1~5

    [题目1]just print a+b give you two var a and b, print the value of a+b, just do it!! print (a + b) [题目 ...

  10. HDU 3081Marriage Match II(二分法+并检查集合+网络流量的最大流量)

    职务地址:http://acm.hdu.edu.cn/showproblem.php? pid=3081 有一段时间没写最大流的题了,这题建图竟然想了好长时间... 刚開始是按着终于的最大流即是做多轮 ...