HDU 4738 Caocao's Bridges taijan (求割边,神坑)
神坑题。这题的坑点有1.判断连通,2.有重边,3.至少要有一个人背炸药
因为有重边,tarjan的时候不能用子结点和父节点来判断是不是树边的二次访问,所以我的采用用前向星存边编号的奇偶性关系,用^1来判断是不是树边
#include<cstdio>
#include<cstring>
#include<algorithm>
using namespace std;
const int maxe = 1000005<<1;
const int maxv = 1005;
int clock;
int dfn[maxv],low[maxv],ecnt;
int head[maxv],nxt[maxe],to[maxe],wei[maxe]; void init()
{
clock = ecnt = 0;
memset(head,-1,sizeof(head));
memset(dfn,0,sizeof(dfn));
} void addEdge(int u,int v,int w)
{
to[ecnt] = v;
wei[ecnt] = w;
nxt[ecnt] = head[u];
head[u] = ecnt++;
} int ans; void tarjan(int u,int fa)
{
dfn[u] = low[u] = ++clock;
for(int i = head[u]; ~i ; i = nxt[i]){
int v = to[i];
if(i == (fa^1)) continue;
if(!dfn[v]){
tarjan(v,i);
low[u] = min(low[u],low[v]);
if(low[v] > dfn[u]){
ans = min(ans,wei[i]);
}
}else {
low[u] = min(low[u],dfn[v]);
}
}
} int sum;
bool vis[maxv];
void dfs(int u){
if(vis[u]) return;
sum++;
vis[u] = 1;
for(int i = head[u]; ~i ; i = nxt[i]){
dfs(to[i]);
}
}
const int INF = 1e9;
int main()
{
int N,M;
while(~scanf("%d%d",&N,&M)&&N){
init();
for(int i = 0; i < M; i++){
int U,V,W;
scanf("%d%d%d",&U,&V,&W);
addEdge(U,V,W);
addEdge(V,U,W);
}
memset(vis,0,sizeof(vis));
sum = 0;
dfs(1);
if(sum < N) { printf("0\n"); continue; }
ans = INF;
tarjan(1,-1);
if(ans == INF) { printf("-1\n"); continue; }
ans = max(ans,1);
printf("%d\n",ans);
}
return 0;
}
HDU 4738 Caocao's Bridges taijan (求割边,神坑)的更多相关文章
- HDU 4738——Caocao's Bridges——————【求割边/桥的最小权值】
Caocao's Bridges Time Limit:1000MS Memory Limit:32768KB 64bit IO Format:%I64d & %I64u S ...
- hdu 4738 Caocao's Bridges (tarjan求桥)
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=4738 题目大意:给一些点,用一些边把这些点相连,每一条边上有一个权值.现在要你破坏任意一个边(要付出相 ...
- 2013杭州网赛 1001 hdu 4738 Caocao's Bridges(双连通分量割边/桥)
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=4738 题意:有n座岛和m条桥,每条桥上有w个兵守着,现在要派不少于守桥的士兵数的人去炸桥,只能炸一条桥 ...
- Hdu 4738 Caocao's Bridges (连通图+桥)
题目链接: Hdu 4738 Caocao's Bridges 题目描述: 有n个岛屿,m个桥,问是否可以去掉一个花费最小的桥,使得岛屿边的不连通? 解题思路: 去掉一个边使得岛屿不连通,那么去掉的这 ...
- HDU 4738 Caocao's Bridges(Tarjan求桥+重边判断)
Caocao's Bridges Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) ...
- HDU 4738 Caocao's Bridges (2013杭州网络赛1001题,连通图,求桥)
Caocao's Bridges Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) ...
- hdu 4738 Caocao's Bridges 图--桥的判断模板
Caocao's Bridges Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) ...
- HDU——4738 Caocao's Bridges
Caocao's Bridges Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) ...
- HDU 4738 Caocao's Bridges
Caocao's Bridges Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) ...
随机推荐
- 3. docker容器内信息获取、命令的执行、容器的导入和导出
一.依附容器 依附操作attach通常用在由docker start或者docker restart启动的交互型容器中.由于docker start启动的交互型容器并没有具体终端可以依附,而容器本身是 ...
- jdbcTemplate简单使用
package com.bizvane.spider.tools; import org.apache.commons.dbcp.BasicDataSource; import org.springf ...
- 当Python中混进一只薛定谔的猫……
本文原创并首发于公众号[Python猫],未经授权,请勿转载. 原文地址:https://mp.weixin.qq.com/s/-fFVTgWVsydFsNu1nyxUzA Python 是一门强大的 ...
- div内textarea 居中
textarea 实现div内居中,可以使用text-align:center,因其为行内元素.
- cat命令详解及here doc
以下内容转自:http://www.cnblogs.com/peida/archive/2012/10/30/2746968.html cat命令的用途是连接文件或标准输入并打印.这个命令常用来显示文 ...
- [Xcode 实际操作]六、媒体与动画-(3)使用CoreImage框架设置图片的单色效果
目录:[Swift]Xcode实际操作 本文将演示如何使用图片框架,将图片转换成单色样式. 在项目导航区,打开视图控制器的代码文件[ViewController.swift] import UIKit ...
- WPF编译时提示"xxx不包含适合于入口点的静态 Main方法xxx"
WPF编译时提示"xxx不包含适合于入口点的静态 Main方法xxx"生成的时候一直报"xxx不包含适合于入口点的静态 Main 方法xxx" 看到这个问题首先 ...
- 黑马旅游网 ajax实现html页面共享
- spring boot 参数转换
参数调用方式: 1. localhost:8080/person/properties/to/json body参数设置: 2. localhost:8080/person/json/to/prope ...
- input accept属性控制选择文件类型
<form> <input type="file" name="pic" id="pic" accept="im ...