图方法:寻找无向图联通子集的JAVA版本
2017-10-24 10:23
453 查看
图像处理中一般使用稠密方法,即对图像进行像素集合进行处理。在图像拓扑方面,更多地应用图计算方法。
寻找无向图联通子集的JAVA版本,代码:
//查找无向图的所有连通子集//wishchin!!!
public static ArrayList<Set<Integer>> findAllCons(Boolean adjM[][]) {
ArrayList<Set<Integer>> conSets = new ArrayList<Set<Integer>>();
Stack<Integer> tree = new Stack<Integer>();
Boolean[] isTra = new Boolean[adjM.length];
for (int i = 0; i < adjM.length; ++i) {
isTra[i] = (false);
}
// 遍历每一行
for (int i = 0; i < adjM.length;) {
if (isTra[i] == true) {
++i;
continue;
}
tree.push(i);
Set<Integer> sub = new HashSet<Integer>();
sub.add(i);
int j = tree.peek();
while (!tree.isEmpty() && isTra[j] == false) {
j = tree.pop();// 取出栈顶i
isTra[j] = true;
// 遍历每一个列
for (int k = 0; k < adjM[j].length; ++k) {
if (false == isTra[k]) {
if (adjM[j][k] == true && isTra[k] == false) {
tree.push(k);// 若K没有被遍历过,则压入栈
sub.add(k);
}
}
}
j = tree.peek();
}
++i;
conSets.add(sub);
}
return conSets;
}
注意事项:
在java中Set类是一个抽象类,不能直接实例化,必须实例化Set的一个子类,比如HashSet。
寻找无向图联通子集的JAVA版本,代码:
//查找无向图的所有连通子集//wishchin!!!
public static ArrayList<Set<Integer>> findAllCons(Boolean adjM[][]) {
ArrayList<Set<Integer>> conSets = new ArrayList<Set<Integer>>();
Stack<Integer> tree = new Stack<Integer>();
Boolean[] isTra = new Boolean[adjM.length];
for (int i = 0; i < adjM.length; ++i) {
isTra[i] = (false);
}
// 遍历每一行
for (int i = 0; i < adjM.length;) {
if (isTra[i] == true) {
++i;
continue;
}
tree.push(i);
Set<Integer> sub = new HashSet<Integer>();
sub.add(i);
int j = tree.peek();
while (!tree.isEmpty() && isTra[j] == false) {
j = tree.pop();// 取出栈顶i
isTra[j] = true;
// 遍历每一个列
for (int k = 0; k < adjM[j].length; ++k) {
if (false == isTra[k]) {
if (adjM[j][k] == true && isTra[k] == false) {
tree.push(k);// 若K没有被遍历过,则压入栈
sub.add(k);
}
}
}
j = tree.peek();
}
++i;
conSets.add(sub);
}
return conSets;
}
注意事项:
在java中Set类是一个抽象类,不能直接实例化,必须实例化Set的一个子类,比如HashSet。
相关文章推荐
- 蛇形矩阵的两种实现方法(java版本)
- xml parser jdk版本切换后出错,解决方法set 应用服务器 jdk/optional java vm arguments:
- 关于2.3版本以下屏蔽Home键的方法(2.3版本中的方法一直寻找中)
- maven打包时出现【java source 1.3中不支持泛型 请使用 -source 5 或更高版本以启用泛型】错误时的解决方法
- Ubuntu安装Java多版本的新方法
- ICTCLAS2013 Java版本的使用方法
- JAVA 寻找-人鬼过河游戏的方法
- ACMjava子集生成的三种方法,增量构造,辅助位向量,二进制法
- HashTable的数组和连接两种实现方法(Java版本)
- 查看java class文件版本的方法
- ICE同步方法调用 java版本
- Java中集合的方法及子集(上)
- Java中集合的方法及子集(下)
- 各个java版本的控制台输入方法比较
- 使用Eclipse进行Java开发,用SVN进行版本控制时的异常解决方法
- ICTCLAS2014 Java版本的使用方法
- 两种方法寻找一个集合的所有子集
- Android4.0-4.4 添加实体按键振动支持的方法(java + smali版本)
- Hibernate 3中对Java 1.5以上版本中枚举类型的映射方法
- 新浪微博oauth2.0接入方法( java 版本)