我学习算法,按照老师给的算法弄的……
利用eclipse编程
完成时间2014年11月24日
package DNFParkge; //求DNF的深度优先递归算法 public class DNFSreach { /** * 这里是文档说明 * 算法如下 *开始 *Start; * * procedure DFS_visit(G,u) * color[u] = Gray;//白色结点u已被发现 * for each edge (u,v)do * if color[u] = White then * DFS_visit(G,v); * repeat color[u]=black;//完成后置u为黑色 * end; * * procedure DFS(G) * for each vertex u 属于V do * color[u] = white * for vertex each u 属于 V do * if color[u]=white * then DFS_visit(G,u) * repeat * * * 构建一个无向图 * 无穷大表示这两个点无边,1表示两者有边 * 白色用1表示,灰色用2表示,黑色用3表示 * 初始状态均为白色 * 搜索中被发现的顶点置为灰色 * 结束时,即其邻接表被完全检索之后,其被置为黑色 * 构建一个color[8]数组,其中color[0]不用 * 初始化为0 * S表示无穷大 * 0 1 2 3 4 5 6 7 8 * ------------------------- * 0 * 1 s 1 1 s s s s s * 2 1 s s 1 1 s s s * 3 1 s s s s 1 1 s * 4 s 1 s s s s s 1 * 5 s 1 s s s s s 1 * 6 s s 1 s s s 1 s * 7 s s 1 s s 1 s s * 8 s s s 1 1 s s s * * 深度优先搜索的结果应该为 * 1-2-4-8-5-3-6-7 * * @param args */ static int color[]; static int d =0; public static void main(String[] args) { int s = Integer.MAX_VALUE; int G[][]={{s,s,s,s,s,s,s,s,s}, {s,s,1,1,s,s,s,s,s}, {s,1,s,s,1,1,s,s,s}, {s,1,s,s,s,s,1,1,s}, {s,s,1,s,s,s,s,s,1}, {s,s,1,s,s,s,s,s,1}, {s,s,s,1,s,s,s,1,s}, {s,s,s,1,s,s,1,s,s}, {s,s,s,s,1,1,s,s,s}}; color = new int [9]; ProcedureDFS(G,9); } public static void ProcedureDFS(int [][]G,int n){ //图是以二维数组的形式保存 //n是二维数组的维数 for(int i=1;i <= n-1;i++){ color[i]=1;//把每一个顶点都置为白色,表示还没搜索 } for(int i=1;i<= n-1;i++){ //对于每一个顶点没被访问的顶点进行访问 if(color[i] == 1){ DFS_visit(G,i);//遍历其访问的顶点 } } } private static void DFS_visit(int[][] g, int i) { // TODO 自动生成的方法存根 color[i] = 2;//标志为灰色,表示被访问过 d++; if(d != g.length-1) System.out.print(""+i+" -> "); if(d == g.length-1) System.out.println(""+i); for(int t=1;t<= g.length-1;t++){ //邻接点没有被访问到 if(color[t] == 1 && g[i][t] != Integer.MAX_VALUE){ DFS_visit(g,t); } } color[i] = 3;//标志位黑色 } }