赞
踩
id
就像是并查集中用来存储元素的数组,存储的是每个节点所属的群体;id
数组的值做 GROUP BY 操作,就得到了这张图的连通分量;ccount
保存;- package bobo.algo;
-
- // 求无权图的联通分量
- public class Components {
-
- Graph G; // 图的引用
- private boolean[] visited; // 记录dfs的过程中节点是否被访问
- private int ccount; // 记录联通分量个数
- private int[] id; // 每个节点所对应的联通分量标记
-
- // 图的深度优先遍历
- void dfs( int v ){
-
- visited[v] = true;
- id[v] = ccount;
-
- for( int i: G.adj(v) ){
- if( !visited[i] )
- dfs(i);
- }
- }
-
- // 构造函数, 求出无权图的联通分量
- public Components(Graph graph){
-
- // 算法初始化
- G = graph;
- visited = new boolean[G.V()];
- id = new int[G.V()];
- ccount = 0;
- for( int i = 0 ; i < G.V() ; i ++ ){
- visited[i] = false;
- id[i] = -1;
- }
-
- // 求图的联通分量
- for( int i = 0 ; i < G.V() ; i ++ )
- if( !visited[i] ){
- dfs(i);
- ccount ++;
- }
- }
-
- // 返回图的联通分量个数
- int count(){
- return ccount;
- }
-
- // 查询点v和点w是否联通
- boolean isConnected( int v , int w ){
- assert v >= 0 && v < G.V();
- assert w >= 0 && w < G.V();
- return id[v] == id[w];
- }
- }
-
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。