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)
嗯,首先边双连通分量(双连通分量之一)是:在一个无向图中,去掉任意的一条边都不会改变此图的连通性,即不存在桥(连通两个边双连通分量的边),称作边双连通分量.一个无向图的每一个极大边双连通子图称作此无向 ...
随机推荐
- powerdesigner 字段添加注释和默认值
powerdesigner 字段添加注释和默认值 2017年01月06日 10:59:02 qingzhuoran 阅读数:27161更多 个人分类: powerdesigner 1.选中表,右键 ...
- hdu 4685(强连通分量+二分图的完美匹配)
传送门:Problem 4685 https://www.cnblogs.com/violet-acmer/p/9739990.html 参考资料: [1]:二分图的最大匹配.完美匹配和匈牙利算法 [ ...
- springboot的跨域
https://www.cnblogs.com/520playboy/p/7306008.html 1.对于前后端分离的项目来说,如果前端项目与后端项目部署在两个不同的域下,那么势必会引起跨域问题的出 ...
- Hadoop基础-HDFS的API常见操作
Hadoop基础-HDFS的API常见操作 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 本文主要是记录一写我在学习HDFS时的一些琐碎的学习笔记, 方便自己以后查看.在调用API ...
- table中表头不动,表体产生滚动条
<div id="elec_table"> 2 <div class="table-head"> 3 <table> 4 & ...
- .NET MVC中的防CSRF攻击
一.CSRF是什么? CSRF(Cross-site request forgery),中文名称:跨站请求伪造,也被称为:one click attack/session riding,缩写为:CSR ...
- JAVA中初始化ArrayList的三种方式
下面讲一下ArrayList初始化的几种不同方式. 一.最常用的初始化方式. List<String> list1 = new ArrayList<String>(); lis ...
- Redis与Mysql数据同步
后台定时任务,定时刷新Redis中信息到数据库.(即Job:定时任务)
- FZU 2254 英语考试
在过三个礼拜,YellowStar有一场专业英语考试,因此它必须着手开始复习. 这天,YellowStar准备了n个需要背的单词,每个单词的长度均为m. YellowSatr准备采用联想记忆法来背诵这 ...
- Neo4j安装&入门&一些优缺点
本篇将介绍Neo4j的安装,入门,和自己使用了一段时间后发现的优点缺点,争取简洁和实用. 如果你是第一次接触Neo4j,并且之前也都没接触过类似的Graph Database的话,建议先浏览一下我之前 ...