图论算法-求(有向)图中任意两点间所有路径

翻译 2016年08月30日 13:44:28

1建图:

     图类中包括如下信息:顶点集合,邻接矩阵。

     节点类中包括如下信息:是否被访问过,节点的名称,从这个节点访问到下一个节点的集合


          


2 算法思路

  A 将始点设置为已访问,将其入栈

  B 查看栈顶节点V在图中,有没有可以到达、且没有入栈、且没有从这个节点V出发访问过的节点

  C 如果有,则将找到的这个节点入栈

  D 如果没有,则将节点V访问到下一个节点的集合中每个元素赋值为零,V出栈

  E 当栈顶元素为终点时,设置终点没有被访问过,打印栈中元素,弹出栈顶节点

  F 重复执行B – E,直到栈中元素为空


package util;

public class Graph {

	private Vertex vertexList[]; // list of vertices
	private int adjMat[][]; // adjacency matrix

	private int nVerts;
	private static int MAX_VERTS = 7; // n个点

	int i = 0;
	int j = 0;

	public Vertex[] getVertexList() {
		return vertexList;
	}

	public int[][] getAdjMat() {
		return adjMat;
	}

	public int getN() {
		return MAX_VERTS;
	}

	public Graph(int index) {
		adjMat = new int[MAX_VERTS][MAX_VERTS]; // 邻接矩阵
		vertexList = new Vertex[MAX_VERTS]; // 顶点数组
		nVerts = 0;

		for (i = 0; i < MAX_VERTS; i++) {
			for (j = 0; j < MAX_VERTS; j++) {
				adjMat[i][j] = 0;
			}
		}

		addVertex('A');
		addVertex('B');
		addVertex('C');
		addVertex('D');
		addVertex('E');
		addVertex('F');
		addVertex('G');

		addEdge(0, 1);
		addEdge(0, 2);
		addEdge(1, 4);
		addEdge(2, 0);
		addEdge(2, 5);
		addEdge(3, 0);
		addEdge(3, 2);
		addEdge(3, 3);
		addEdge(4, 1);
		addEdge(4, 2);
		addEdge(5, 6);
		addEdge(6, 3);

		switch (index) {
		case 0:
			break;
		case 1:
			delEdge(4, 2);
			break;
		default:
			break;
		}
	}

	private void delEdge(int start, int end) {
		adjMat[start][end] = 0;
	}

	private void addEdge(int start, int end) {// 有向图,添加边
		adjMat[start][end] = 1;
		// adjMat[end][start] = 1;
	}

	public void addVertex(char lab) {
		vertexList[nVerts++] = new Vertex(lab);// 添加点
	}

	public char displayVertex(int i) {
		return vertexList[i].getLabel();
	}

	public boolean displayVertexVisited(int i) {
		return vertexList[i].WasVisited();
	}

	public void printGraph() {
		for (i = 0; i < MAX_VERTS; i++) {
			System.out.print("第" + displayVertex(i) + "个节点:" + " ");

			for (j = 0; j < MAX_VERTS; j++) {
				System.out.print(displayVertex(i) + "-" + displayVertex(j)
						+ ":" + adjMat[i][j] + " ");
			}
			System.out.println();
		}

	}

}

import java.util.ArrayList;

public class Vertex {

	boolean wasVisited; // 是否遍历过
	public char label; // 节点名称
	ArrayList<Integer> allVisitedList;// 节点已访问过的顶点

	public void setAllVisitedList(ArrayList<Integer> allVisitedList) {
		this.allVisitedList = allVisitedList;
	}

	public ArrayList<Integer> getAllVisitedList() {
		return allVisitedList;
	}

	public boolean WasVisited() {
		return wasVisited;
	}

	public void setWasVisited(boolean wasVisited) {
		this.wasVisited = wasVisited;
	}

	public char getLabel() {
		return label;
	}

	public void setLabel(char label) {
		this.label = label;
	}

	public Vertex(char lab) // constructor
	{
		label = lab;
		wasVisited = false;
	}

	public void setVisited(int j) {
		allVisitedList.set(j, 1);

	}

}


import util.Graph;

public class Main {

	public static void main(String[] args) {
        //第几张图,有两张(0,1),起点序号(0-6),终点序号(0-6)
		AF operation = new AF(new Graph(0), 3, 6);
		operation.getResult();

	}
}

源码下载:http://download.csdn.net/detail/ha000/9616787

设计并实现求两点间所有路径的算法

Project 1实验题目设计并实现求两点间所有路径的算法。程序设计DFS算法 深度优先遍历: 深度优先搜索(Depth_First Search)遍历类似于树的先根遍历,是树的先根遍历的推广。 ...
  • Thingvellir
  • Thingvellir
  • 2017年03月30日 23:16
  • 1223

求两点间所有路径的遍历算法

1、深度优先遍历     1.1 深度优先遍历的定义     深度优先搜索(Depth_First Search)遍历类似于树的先根遍历,是树的先根遍历的推广。 假设给定图G,图中所有顶点未曾被...
  • lysc_forever
  • lysc_forever
  • 2013年12月23日 10:45
  • 15016

求图中两点间的所有路径(包括最短路径)——vs2008下实现

  • 2010年06月29日 18:06
  • 416KB
  • 下载

图论基本定义和术语

1.图的定义          图(Graph)是由两个集合构成,一个是非空但是有限的顶点集合V,另一个是描述结合间的关系边的集合E,因此图可以表示为G=(V,E).每条边是一对顶点(v,w)且 v...
  • Tander_Tang
  • Tander_Tang
  • 2016年03月21日 20:53
  • 2578

求无向图中指定两个节点间的所有路径

百度面试题://邻接矩阵的遍历 typedef struct{ int amount; int *vex; int **matrix; }Graph; //打印从i到j的所有回路 void P...
  • panghuizl
  • panghuizl
  • 2011年10月28日 17:39
  • 5182

Java找出图中两点之间所有路径

Java找出图中两点之间所有路径 本实例图基于邻接表 图类: package graph1; import java.util.LinkedList; import graph.Gr...
  • Coder_py
  • Coder_py
  • 2017年05月19日 16:46
  • 1246

两点间所有路径的遍历算法

两点间所有路径的遍历算法 中国海洋大学 信息科学与工程学院 熊建设 梁磊 摘要:本文首先简单介绍图的深度优先遍历算法,接着根据图的深度优先遍历算法求出连通图中两点间所有路径,并给出代码。 ...
  • agfagafsdfas
  • agfagafsdfas
  • 2014年11月22日 22:17
  • 409

图论算法-求(有向)图中任意两点间所有路径

  • 2016年08月30日 13:53
  • 98KB
  • 下载

C++求图任意两点间的所有路径

基于连通图,邻接矩阵实现的图,非递归实现。 算法思想: 设置两个标志位,①该顶点是否入栈,②与该顶点相邻的顶点是否已经访问。   A 将始点标志位①置1,将其入栈   B 查看栈顶节点V在图中,有没有...
  • wind_liang
  • wind_liang
  • 2016年06月28日 22:56
  • 2607

基于深度遍历DFS思想实现寻找两点间所有简单路径的寻找

实现的功能:求两点间的所有简单路径 题目:     思路:基于深度遍历的思想     首先是图的ADT的编写,图的ADT中主要包括     私有成员 numVertex(用于记录节点个...
  • Xiaobai__Lee
  • Xiaobai__Lee
  • 2016年12月24日 15:29
  • 2038
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:图论算法-求(有向)图中任意两点间所有路径
举报原因:
原因补充:

(最多只允许输入30个字)