Expm 9_3 无向图的双连通分量问题
【问题描述】
给定一个无向图,设计一个算法,判断该图中是否存在关节点,并划分双连通分量。
package org.xiu68.exp.exp9;
import java.util.Stack;
public class Exp9_3 {
//无向图的双连通分量问题
public static void main(String[] args) {
// TODO Auto-generated method stub
int[][] graph=new int[][]{
{0,1,1,0,0},
{1,0,1,0,0},
{1,1,0,1,1},
{0,0,1,0,1},
{0,0,1,1,0}
};
MGraph1 m=new MGraph1(graph);
m.bicompDFS(0);
//运行结果
/*
双连通部件:
(4,2) (3,4) (2,3)
双连通部件:
(2,0) (1,2) (0,1)
*/
}
}
//邻接矩阵表示无向图
class MGraph1{
private int vexNum; //顶点数量
private int[][] edges; //边
private Stack<Edge> edgeStack; //边栈
private int[][] visitedEdge; //记录哪条边已经访问过,1为访问过,0为未访问过
private int[] color; //记录顶点的访问状态,-1为未访问到,0为正在搜索中,1为已搜索完成
private int clock; //访问时刻
private int[] pre; //记录顶点的访问时间
private int[] post; //记录顶点的结束访问时刻
public MGraph1(int[][] edges) {
this.edges = edges;
this.vexNum=edges.length;
this.color=new int[vexNum];
this.pre=new int[vexNum];
this.post=new int[vexNum];
this.clock=1;
this.edgeStack=new Stack<>();
this.visitedEdge=new int[vexNum][vexNum];
//初始化所有结点为未访问状态
for(int i=0;i<vexNum;i++){
color[i]=-1;
}
}
//返回从v出发,经过一条其后代组成的边包括回退边,所能访问到的顶点的最小的pre值
public int bicompDFS(int v){
//color[v]的值:-1为未访问到,0为正在搜索中,1为已搜索完成
color[v]=0; //顶点v正在搜索中
pre[v]=clock; //顶点v的访问时刻
clock++;
int back=pre[v]; //表示从v出发,经过一条其后代组成的边包括回退边,所能访问到的顶点的最小的pre值
for(int i=0;i<vexNum;i++){
if(edges[v][i]==1 && color[i]!=1 && visitedEdge[v][i]!=1){ //顶点v和i之间有边未访问过
edgeStack.push(new Edge(v,i)); //放入边栈中
visitedEdge[v][i]=visitedEdge[i][v]=1; //记录边已访问过
if(color[i]==-1){ //树边
int wBack=bicompDFS(i);
if(wBack>=pre[v]){ //说明v的子树没有回路关联到v的祖先
System.out.println("双连通部件: ");
Edge e=edgeStack.pop();
while(true){
System.out.print("("+e.getHead()+","+e.getTail()+") ");
if(e.getHead()==v && e.getTail()==i)
break;
e=edgeStack.pop();
}
System.out.println();
}
if(wBack<back)
back=wBack; //记录从v开始经过的顶点的最小的pre值
}else if(color[i]==0){ //回边
if(pre[i]<back)
back=pre[i]; //记录从v开始经过的顶点的最小的pre值
}
}//if
}//for
post[v]=clock;
clock++;
color[v]=1;
return back;
}
}
class Edge{
private int head; //边的头
private int tail; //边的尾
public Edge(int head,int tail){
this.head=head;
this.tail=tail;
}
public int getHead() {
return head;
}
public void setHead(int head) {
this.head = head;
}
public int getTail() {
return tail;
}
public void setTail(int tail) {
this.tail = tail;
}
}
Expm 9_3 无向图的双连通分量问题的更多相关文章
- POJ 3352 无向图边双连通分量,缩点,无重边
为什么写这道题还是因为昨天多校的第二题,是道图论,HDU 4612. 当时拿到题目的时候就知道是道模版题,但是苦于图论太弱.模版都太水,居然找不到. 虽然比赛的时候最后水过了,但是那个模版看的还是一知 ...
- poj 2942 Knights of the Round Table(无向图的双连通分量+二分图判定)
#include<cstdio> #include<cstring> #include<cmath> #include<cstdlib> #includ ...
- [Tarjan系列] Tarjan算法求无向图的双连通分量
这篇介绍如何用Tarjan算法求Double Connected Component,即双连通分量. 双联通分量包括点双连通分量v-DCC和边连通分量e-DCC. 若一张无向连通图不存在割点,则称它为 ...
- UVALive 3523 Knights of the Round Table 圆桌骑士 (无向图点双连通分量)
由于互相憎恨的骑士不能相邻,把可以相邻的骑士连上无向边,会议要求是奇数,问题就是求不在任意一个简单奇圈上的结点个数. 如果不是二分图,一定存在一个奇圈,同一个双连通分量中其它点一定可以加入奇圈.很明显 ...
- Road Construction(无向图的双连通分量)
http://poj.org/problem?id=3352 题意:给出一个有n个顶点m条边的无向连通图,问至少添加几条边,使删除任意一条边原图仍连通. 思路:一个边双连通图删除任意一条边仍为连通图. ...
- UVALive-5135 Mining Your Own Business (无向图的双连通分量)
题目分析:在一张无向图中,将一些点涂上黑色,使得删掉图中任何一个点时,每个连通分量至少有一个黑点.问最少能涂几个黑点,并且在涂最少的情况下有几种方案. 题目分析:显然,一定不能涂割点.对于每一个连通分 ...
- hdu Caocao's Bridges(无向图边双连通分量,找出权值最小的桥)
/* 题意:给出一个无向图,去掉一条权值最小边,使这个无向图不再连同! tm太坑了... 1,如果这个无向图开始就是一个非连通图,直接输出0 2,重边(两个节点存在多条边, 权值不一样) 3,如果找到 ...
- DFS的运用(二分图判定、无向图的割顶和桥,双连通分量,有向图的强连通分量)
一.dfs框架: vector<int>G[maxn]; //存图 int vis[maxn]; //节点访问标记 void dfs(int u) { vis[u] = ; PREVISI ...
- 无向图的边双连通分量(EBC)
嗯,首先边双连通分量(双连通分量之一)是:在一个无向图中,去掉任意的一条边都不会改变此图的连通性,即不存在桥(连通两个边双连通分量的边),称作边双连通分量.一个无向图的每一个极大边双连通子图称作此无向 ...
随机推荐
- Eclipse:构造函数不提示才发现
用Eclipse快一年了,今天才发现,原来按下 Alt+? 就可以显示构造函数中的参数. 想一想这一年都不知道是怎么过的,遇到构造函数时,郁闷啊... 2007-11-01
- javascript:location.reload()和location.replace()的区别,及对图片缓存的影响。
有段时间没有清理IE的临时文件(缓存文件),在我清理的时候,我突然发现一个问题. 我打开的一个网站,图片默认缓存一个月的,但我发现,当我上传图片或删除图片之后,图片重新缓存,也就意味着,在我上传新图片 ...
- Sublime Text3—系统设置
摘要 软件的设置分为系统设置和快捷键设置两项,这次分享系统设置,Sublime Text3-自带快捷键介绍前面已分享过. 正文 菜单依次选择Preferences | Settings,我们修改设置不 ...
- Gradle 从svn 中检出的父项目后处理配置【我】
前提: 一个用gradle配置的 类似maven的聚合项目的项目,然后它在svn上就是一个父工程的目录. 检出方式: 在eclipse中,直接用svn资源库检出 父项目 的目录. 然后,在父项目下面的 ...
- Eclipse Jee Oxygen安装svn插件
转: Eclipse Jee Oxygen安装svn插件 技术标签: eclipse svn Eclipse Jee Oxygen安装svn插件 入主题: 选择Eclipse->菜单-> ...
- 2018.10.2浪在ACM 集训队第二次测试赛
2018.10.26 浪在ACM 集训队第二次测试赛 题目一览表 来源 考察知识点 A 1273 海港 NOIP 普及组 2016 差分数组+二分 B 1274 魔法阵 C 1267 金币 ...
- Quadratic.java
/****************************************************************************** * Compilation: javac ...
- 个股与指数的回归分析(自带python ols 参数解读)
sklearn实战-乳腺癌细胞数据挖掘(博客主亲自录制视频教程) https://study.163.com/course/introduction.htm?courseId=1005269003&a ...
- GC.SuppressFinalize()的正确用法
SuppressFinalize函数是: 该方法在对象头中设置一个位,系统在调用终结器时将检查这个位.obj 参数应为此方法的调用方. 实现 IDisposable 接口的对象可以从 IDisposa ...
- 使用 CSS3 的 box-sizing 属性设置元素大小包含 border 与 padding
Ø 默认情况下,内部元素(如:input)的宽度或高度,是不会包含元素的边框和内边距的,这时就需要使用 box-sizing 属性设置该元素. Ø box-sizing 是 CSS3 的属性,可以 ...