邻接表无向图的介绍
邻接表无向图是指通过邻接表表示的无向图。
上面的图G1包含了"A,B,C,D,E,F,G"共7个顶点,而且包含了"(A,C),(A,D),(A,F),(B,C),(C,D),(E,G),(F,G)"共7条边。
上图右边的矩阵是G1在内存中的邻接表示意图。每一个顶点都包含一条链表,该链表记录了"该顶点的邻接点的序号"。例如,第2个顶点(顶点C)包含的链表所包含的节点的数据分别是"0,1,3";而这"0,1,3"分别对应"A,B,D"的序号,"A,B,D"都是C的邻接点。就是通过这种方式记录图的信息的。
邻接表无向图的代码说明
1. 基本定义
public class ListUDG {
// 邻接表中表对应的链表的顶点
private class ENode {
int ivex; // 该边所指向的顶点的位置
ENode nextEdge; // 指向下一条弧的指针
}
// 邻接表中表的顶点
private class VNode {
char data; // 顶点信息
ENode firstEdge; // 指向第一条依附该顶点的弧
};
private VNode[] mVexs; // 顶点数组
...
}
(01) ListUDG是邻接表对应的结构体。mVexs则是保存顶点信息的一维数组。
(02) VNode是邻接表顶点对应的结构体。 data是顶点所包含的数据,而firstEdge是该顶点所包含链表的表头指针。
(03) ENode是邻接表顶点所包含的链表的节点对应的结构体。 ivex是该节点所对应的顶点在vexs中的索引,而nextEdge是指向下一个节点的。
2. 创建矩阵
这里介绍提供了两个创建矩阵的方法。一个是用已知数据,另一个则需要用户手动输入数据。
2.1 创建图(用已提供的矩阵)
/*
* 创建图(用已提供的矩阵)
*
* 参数说明:
* vexs -- 顶点数组
* edges -- 边数组
*/
public ListUDG(char[] vexs, char[][] edges) {
// 初始化"顶点数"和"边数"
int vlen = vexs.length;
int elen = edges.length;
// 初始化"顶点"
mVexs = new VNode[vlen];
for (int i = 0; i < mVexs.length; i++) {
mVexs[i] = new VNode();
mVexs[i].data = vexs[i];
mVexs[i].firstEdge = null;
}
// 初始化"边"
for (int i = 0; i < elen; i++) {
// 读取边的起始顶点和结束顶点
char c1 = edges[i][0];
char c2 = edges[i][1];
// 读取边的起始顶点和结束顶点
int p1 = getPosition(edges[i][0]);
int p2 = getPosition(edges[i][1]);
// 初始化node1
ENode node1 = new ENode();
node1.ivex = p2;
// 将node1链接到"p1所在链表的末尾"
if(mVexs[p1].firstEdge == null)
mVexs[p1].firstEdge = node1;
else
linkLast(mVexs[p1].firstEdge, node1);
// 初始化node2
ENode node2 = new ENode();
node2.ivex = p1;
// 将node2链接到"p2所在链表的末尾"
if(mVexs[p2].firstEdge == null)
mVexs[p2].firstEdge = node2;
else
linkLast(mVexs[p2].firstEdge, node2);
}
}
该函数的作用是创建一个邻接表无向图。实际上,该方法创建的无向图,就是上面图G1。调用代码如下:
char[] vexs = {'A', 'B', 'C', 'D', 'E', 'F', 'G'};
char[][] edges = new char[][]{
{'A', 'C'},
{'A', 'D'},
{'A', 'F'},
{'B', 'C'},
{'C', 'D'},
{'E', 'G'},
{'F', 'G'}};
ListUDG pG;
pG = new ListUDG(vexs, edges);
2.2 创建图(自己输入)
/*
* 创建图(自己输入数据)
*/
public ListUDG() {
// 输入"顶点数"和"边数"
System.out.printf("input vertex number: ");
int vlen = readInt();
System.out.printf("input edge number: ");
int elen = readInt();
if ( vlen < 1 || elen < 1 || (elen > (vlen*(vlen - 1)))) {
System.out.printf("input error: invalid parameters!\n");
return ;
}
// 初始化"顶点"
mVexs = new VNode[vlen];
for (int i = 0; i < mVexs.length; i++) {
System.out.printf("vertex(%d): ", i);
mVexs[i] = new VNode();
mVexs[i].data = readChar();
mVexs[i].firstEdge = null;
}
// 初始化"边"
//mMatrix = new int[vlen][vlen];
for (int i = 0; i < elen; i++) {
// 读取边的起始顶点和结束顶点
System.out.printf("edge(%d):", i);
char c1 = readChar();
char c2 = readChar();
int p1 = getPosition(c1);
int p2 = getPosition(c2);
// 初始化node1
ENode node1 = new ENode();
node1.ivex = p2;
// 将node1链接到"p1所在链表的末尾"
if(mVexs[p1].firstEdge == null)
mVexs[p1].firstEdge = node1;
else
linkLast(mVexs[p1].firstEdge, node1);
// 初始化node2
ENode node2 = new ENode();
node2.ivex = p1;
// 将node2链接到"p2所在链表的末尾"
if(mVexs[p2].firstEdge == null)
mVexs[p2].firstEdge = node2;
else
linkLast(mVexs[p2].firstEdge, node2);
}
}
该函数是读取用户的输入,将输入的数据转换成对应的无向图。
源码:https://github.com/wangkuiwu/datastructs_and_algorithm/blob/master/source/graph/iterator/udg/java/ListUDG.java
http://www.cnblogs.com/skywang12345/p/3707612.html
相关推荐
邻接表无向图的Java语言实现完整 邻接表无向图是一种常见的图数据结构,它通过邻接表表示无向图。在Java语言中,实现邻接表无向图需要定义相应的数据结构和算法。下面是关于邻接表无向图的Java语言实现的知识点: ...
// 对于无向图,边是双向的 } } // 遍历图 public void traverse(int start, boolean isDFS) { if (vertices.containsKey(start)) { Stack<Node> stack = new Stack(); // 用于深度优先遍历 Queue<Node> ...
根据图中边的方向不同,可以将图分为有向图和无向图。为了有效地存储和操作图数据,邻接表是一种常用的图存储方式。 #### 二、邻接表存储结构 邻接表是通过链式结构来存储图的边或弧的一种方法,对于一个包含n个...
Java无向图最短主树(Minimum Spanning Tree, MST)生成程序是一个经典的算法问题,主要应用于网络设计、运输规划等领域。在这个程序中,我们利用Java语言来解决这个问题,通过读取用户输入的无向图数据,计算并输出...
对于无向图,矩阵是对称的,而对于有向图,边的方向会影响矩阵的非对称性。邻接矩阵适用于表示稠密图(边的数量接近于节点数量的平方),因为它能直接表示任意两个节点之间的关系,但空间效率较低。 深度优先遍历是...
4. 拓扑排序:对于有向无环图(DAG),可以按照没有前驱的顺序排列所有顶点。 5. 最短路径算法:如Dijkstra算法或Floyd-Warshall算法,用于找到两个顶点之间的最短路径。 在编程实现时,可以使用各种编程语言,如...
在Java实现中,通常会使用邻接矩阵或邻接表来表示无向图。邻接矩阵是一个二维数组,其中元素值表示两个网页之间是否存在链接;邻接表则使用链表或集合存储每个节点的邻居。对于大规模图,邻接表更节省空间。 以下是...
开发者可能定义了数据结构来表示无向图,如邻接矩阵或邻接表,然后实现了相应的最短路径算法。代码可能还包括了输入/输出功能,以便读取图的结构和打印出最短路径结果。 为了更好地理解并利用这个项目,你需要熟悉...
本主题将详细介绍有向图和无向图的深度优先遍历(DFS)与宽度优先遍历(BFS),并探讨递归和非递归两种实现方式。 首先,我们来理解有向图和无向图的区别。有向图的边具有方向性,即从一个节点指向另一个节点,而无...
对任意给定的图(顶点数不小于20,边数不少于30,图的类型可以是有向图、无向图、有向网、无向网),能够输入图的顶点和边(或弧)的信息,并存储到相应存储结构(邻接矩阵、邻接表、十字链表、邻接多重表,任选其中...
1. **图的表示**:无向图可以使用邻接矩阵或邻接表来存储。邻接矩阵是一个二维数组,其中的元素表示顶点之间的连接关系;邻接表则更节省空间,它为每个顶点维护一个链表,链表中的节点表示与该顶点相连的所有其他...
java搜索无向图中两点之间所有路径的算法 java搜索无向图中两点之间所有路径的算法是计算机科学中的一种重要算法,它可以在无向图中找到两点之间的所有路径。该算法的实现思路是首先整理节点间的关系,为每个节点...
此外,实验还包括无向图的广度优先搜索遍历过程,即首先访问出发点V,接着访问V的所有邻接点W1、W2、⋯、Wt,然后再依次访问与W1、W2、⋯、Wt邻接的所有未访问过的顶点,直到图中所有与初始出发点Vi有路径相通的顶点...
在Java中,无向图通常通过邻接矩阵或邻接表来表示。邻接矩阵是一个二维数组,每个元素表示对应节点之间是否存在边;邻接表则使用链表或队列等数据结构存储每个节点的相邻节点。 在"GraphMatrix.java"文件中,我们...
无向图的邻接表通常用于DFS,因为它更节省空间,特别是对于稀疏图(边的数量远小于节点数量的平方)。邻接表是由节点的邻接节点组成的链表,而不是邻接矩阵,后者在处理大规模图时可能会浪费大量内存。 在实际应用...
无向图的存储方式主要有两种:邻接矩阵和邻接表。这里我们重点讨论邻接矩阵。 **邻接矩阵** 是一种二维数组,用于存储图中顶点之间的邻接关系。对于一个包含n个顶点的图,邻接矩阵是一个n×n的矩阵,其中的元素通常...
在Java中实现这一功能,我们可以使用邻接矩阵来表示无向图。邻接矩阵是一个二维数组,其中的元素表示对应节点之间是否存在边。若存在边,元素值为1,否则为0。以下是一些关键步骤: 1. **读取矩阵**:首先,我们...
例如,我们可以使用Java集合框架中的接口和类,如`Graph`(图)、`Vertex`(顶点)和`Edge`(边),来抽象和操作无向图。此外,可以借助图算法,如Dijkstra算法、Floyd-Warshall算法或者A*搜索算法,来寻找从起点到...
无向图最短路径是图论中的一个经典问题,在计算机科学和网络算法中有着广泛的应用。...本代码包中的实现,使用Java编程语言,提供了多种无向图最短路径算法的实现,可以帮助开发者更好地理解和运用这些算法。
对于无向图,矩阵是对称的,因为边i到j和j到i是等价的。对于有向图,矩阵可能不对称。 在Java中,我们可以创建一个二维整数数组来表示邻接矩阵。例如,对于一个包含n个节点的图,我们可以定义一个n×n的数组。下面...