hdu4738Caocao's Bridges
什么?有人要炸我的桥?!D飞他(心疼周瑜大都督)
这个就是求割边/桥了。
- #include<cstdio>
- #include<iostream>
- #include<cstring>
- #include<cstdlib>
- #include<algorithm>
- #include<cmath>
- using namespace std;
- int n,m;
- struct node
- {
- int x,y,d,t,next;
- }a[];int len,last[];
- void ins(int x,int y,int d,int t)
- {
- len++;
- a[len].x=x;a[len].y=y;a[len].d=d;a[len].t=t;
- a[len].next=last[x];last[x]=len;
- }
- int z,dfn[],low[];
- int top,sta[];
- int bp,bridge[];
- void tarjan(int x,int pre)
- {
- dfn[x]=low[x]=++z;
- sta[++top]=x;
- for(int k=last[x];k;k=a[k].next)
- {
- int y=a[k].y;
- if(dfn[y]==)
- {
- tarjan(y,k);
- low[x]=min(low[x],low[y]);
- }
- else if(a[pre].t!=a[k].t)
- low[x]=min(low[x],dfn[y]);
- }
- if(dfn[x]==low[x])
- {
- if(pre!=)
- bridge[++bp]=pre;
- int i;
- do{
- i=sta[top];top--;
- }while(i!=x);
- }
- }
- int main()
- {
- while(scanf("%d%d",&n,&m)!=EOF)
- {
- if(n==&&m==)break;
- int x,y,d;
- len=;memset(last,,sizeof(last));
- for(int i=;i<=m;i++)
- {
- scanf("%d%d%d",&x,&y,&d);
- ins(x,y,d,i);ins(y,x,d,i);
- }
- z=top=bp=;
- memset(dfn,,sizeof(dfn));
- memset(low,,sizeof(low));
- tarjan(,);
- bool bk=true;
- for(int i=;i<=n;i++)
- if(dfn[i]==){bk=false;break;}
- if(bk==false){printf("0\n");continue;}
- int ans=(<<);
- for(int i=;i<=bp;i++)
- ans=min(ans,a[bridge[i]].d);
- printf("%d\n",(ans==(<<))?-:((ans==)?:ans));
- }
- return ;
- }
hdu4738Caocao's Bridges的更多相关文章
- hdu 4738 Caocao's Bridges 图--桥的判断模板
Caocao's Bridges Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) ...
- POJ2288 Islands and Bridges
Description Given a map of islands and bridges that connect these islands, a Hamilton path, as we al ...
- 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
Caocao's Bridges Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) ...
- ZOJ 2588 Burning Bridges(求含重边的无向连通图的割边) - from lanshui_Yang
Burning Bridges Time Limit: 5 Seconds Memory Limit: 32768 KB Ferry Kingdom is a nice little country ...
- zoj 2588 Burning Bridges【双连通分量求桥输出桥的编号】
Burning Bridges Time Limit: 5 Seconds Memory Limit: 32768 KB Ferry Kingdom is a nice little cou ...
- hdoj 4738 Caocao's Bridges【双连通分量求桥】
Caocao's Bridges Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) ...
- bzoj 2095: [Poi2010]Bridges [混合图欧拉回路]
2095: [Poi2010]Bridges 二分答案,混合图欧拉路判定 一开始想了一个上下界网络流模型,然后发现不用上下界网络流也可以 对于无向边,强制从\(u \rightarrow v\),计算 ...
- Luogu4655 [CEOI2017]Building Bridges
Luogu4655 [CEOI2017]Building Bridges 有 \(n\) 根柱子依次排列,每根柱子都有一个高度.第 \(i\) 根柱子的高度为 \(h_i\) . 现在想要建造若干座桥 ...
随机推荐
- Python之IPython开发实践
Python之IPython开发实践 1. IPython有行号. 2. Tab键自动完成,当前命名空间任何与已输入字符串相匹配的变量就会被找出来. 3. 内省机制,在变量前或者后面加上(?)问号,就 ...
- 【PL/SQL】触发器示例:记录加薪
首先创建一张表,用于保存薪资变化情况: --创建加薪记录表 CREATE TABLE scott.raisedsalarylog ( empno ) NOT NULL PRIMARY KEY, --员 ...
- css图片高清适配
同一张图片,在普通屏显示正常,但高清屏出现模糊.原因是原来一个像素的点分成的四个像素的点进行了显示. 解决方案:在高清屏中把图片变成二倍图,前提是二倍的高清图已经存在. .icon{ backgrou ...
- centos添加永久的环境变量
cd /etc/profile.d/ 创建一个sh文件 vi dotnetpath.sh 内容如下: export PATH=$PATH:/opt/dotnet 保存,重启,这就有了一个永久的环境变量
- Java-Class-Miniprogram:com.ylbtech.common.utils.miniprogram.TemplateMessage
ylbtech-Java-Class-Miniprogram:com.ylbtech.common.utils.miniprogram.TemplateMessage 1.返回顶部 1.1. pack ...
- hdu 2084 数塔(简单dp)
题目 简单dp //简单的dp #include<stdio.h> #include<string.h> #include<algorithm> using nam ...
- My97DatePicker 开始日期不能大于 结束日期
My97DatePicker 日期控制,开始时间不能>结束时间,结束时间不能<开始时间 <li>日期:<input type="text" style ...
- String s="a"+"b"+"c"+"d";创建了几个对象?
对于如下代码: package reviewTest; /** * @ClassName: StringTest * @Description: 测试String的字符串相加优化 * @author ...
- odoo 二次开发小记-----不定时更新
一.odoo中 页面上字段变化引起其他字段范围变化-onchange @api.onchange('company_id') def onchange_parent_id(self): return ...
- SpringMVC demo 小例子,实现简单的登录和注册
1.创建一个动态的web工程 2.导入springMvc所需要的jar包(这里可以去网上找,资源有很多) 前两部就不详细描述了,后面才是正经代码~ 首先有一个web.xml文件,这个属于大配置文件,由 ...