JAVA实现图的邻接表以及DFS
一:定义邻接表结构储存图
package 图的遍历; //邻接表实现图的建立 //储存边
class EdgeNode {
int index; // 习惯了用index,其实标准写法是(adjVertex)
int value; // 权值
EdgeNode nextArc; // 指向下一条弧
} // 邻接表节点的类型
class VertexNode {
String name;
EdgeNode firstArc = new EdgeNode(); // 指向第一条弧
} public class Graph {
VertexNode[] adjList; // 保存邻接表的头节点
int e; // 图的边数
int v; // 图的顶点数
boolean[] visit; public Graph(int v, int e) {
this.v = v;
this.e = e;
adjList = new VertexNode[e + 1]; // 学习Java养成的好习惯,动态分配空间,创建顶点表数组
visit = new boolean[e + 1]; //标记
for (int i = 0; i < e; i++) {
visit[i] = false;
}
}
}
二:DFS过程
package 图的遍历; public class DFSGraph {
public static void DFS(Graph G, int k) {
System.out.println(G.adjList[k].name);
G.visit[k] = true;
EdgeNode p = new EdgeNode();
p = G.adjList[k].firstArc;
while(p!=null){
if(G.visit[p.index]!=true){
DFS(G,p.index);
} p=p.nextArc;
}
} }
三:建立图
package 图的遍历; import java.util.Scanner; public class CreateGraph {
private static Graph G;
public static Graph getGraph(){
return G;
}
public static void createGraph() {
Scanner sc = new Scanner(System.in);
System.out.println("请输入顶点数v和边数e:");
int v = sc.nextInt();
int e = sc.nextInt();
G = new Graph(v, e);
System.out.println("请输入各顶点信息:");
for (int i = 0; i < G.v; i++) {
G.adjList[i] = new VertexNode();
G.adjList[i].name = sc.next();
G.adjList[i].firstArc = null; // 不可或缺
}
System.out.println("请输入各边信息(用空格隔开):");
for (int i = 0; i < G.e; i++) {
EdgeNode en1 = new EdgeNode();
// 保证e1,e2都是合法输入
String e1 = sc.next();
String e2 = sc.next();
int v1 = Index(e1);
int v2 = Index(e2);
en1.index = v1; // en1的下标是v1
en1.nextArc = G.adjList[v2].firstArc;
G.adjList[v2].firstArc = en1; EdgeNode en2 = new EdgeNode();
en2.index = v2; // en2的下标是v2
en2.nextArc = G.adjList[v1].firstArc;
G.adjList[v1].firstArc = en2;
}
}
public static void outputGraph() { //不知道为何空指针异常
try {
System.out.println("输出邻接表存储情况:");
EdgeNode en = new EdgeNode();
for (int i = 0; i < G.e; i++) {
System.out.print(G.adjList[i].name);
en = G.adjList[i].firstArc;
while (en != null) {
System.out.print("->" + G.adjList[en.index].name);
en = en.nextArc;
}
System.out.println();
}
} catch (NullPointerException e) { } }
private static int Index(String e1) {
for (int i = 0; i < G.v; i++) {
if (G.adjList[i].name.equals(e1)){
return i;
}
}
return -1;
}
}
四:测试
package 图的遍历; public class GraphDemo {
public static void main(String[] args) {
CreateGraph.createGraph();
CreateGraph.outputGraph(); System.out.println("DFS图的过程如下:");
DFSGraph.DFS(CreateGraph.getGraph() , 0);
}
}
/*
* 请输入顶点数v和边数e: 4 5
* 请输入各顶点信息: a b c d
* 请输入各边信息(用空格隔开):
* a b
* a c
* a d
* b c
* b d
*/
五,测试结果
JAVA实现图的邻接表以及DFS的更多相关文章
- 数据结构学习笔记05图 (邻接矩阵 邻接表-->BFS DFS、最短路径)
数据结构之图 图(Graph) 包含 一组顶点:通常用V (Vertex) 表示顶点集合 一组边:通常用E (Edge) 表示边的集合 边是顶点对:(v, w) ∈E ,其中v, w ∈ V 有向边& ...
- PAT1013. Battle Over Cities(邻接矩阵、邻接表分别dfs)
//采用不同的图存储结构结构邻接矩阵.邻接表分别dfs,我想我是寂寞了吧,应该试试并查集,看见可以用并查集的就用dfs,bfs代替......怕了并查集了 //邻接矩阵dfs #include< ...
- 数据结构之---C语言实现图的邻接表存储表示
// 图的数组(邻接矩阵)存储表示 #include <stdio.h> #include <stdlib.h> #include <string.h> #defi ...
- c_数据结构_图_邻接表
课程设计------邻接表 图的遍历实现课程设计:https://files.cnblogs.com/files/Vera-y/图的遍历_课程设计.zip #include<stdio.h> ...
- 图的邻接表存储表示(C)
//---------图的邻接表存储表示------- #include<stdio.h> #include<stdlib.h> #define MAX_VERTEXT_NUM ...
- 图的邻接表存储 c实现
图的邻接表存储 c实现 (转载) 用到的数据结构是 一个是顶点表,包括顶点和指向下一个邻接点的指针 一个是边表, 数据结构跟顶点不同,存储的是顶点的序号,和指向下一个的指针 刚开始的时候把顶点表初始化 ...
- 基于visual Studio2013解决算法导论之053图的邻接表表示
题目 图的邻接表表示 解决代码及点评 // 图的邻接表表示.cpp : 定义控制台应用程序的入口点. // #include <iostream> #include <sta ...
- 图的全部实现(邻接矩阵 邻接表 BFS DFS 最小生成树 最短路径等)
1 /** 2 * C: Dijkstra算法获取最短路径(邻接矩阵) 3 * 6 */ 7 8 #include <stdio.h> 9 #include <stdlib.h> ...
- 用邻接表实现DFS和BFS
#include <stdio.h> #include <stdlib.h> #define MAXVERTEX 10 typedef char VertexType; //顶 ...
随机推荐
- 洛谷P1948 [USACO08JAN]电话线Telephone Lines
题目描述 Farmer John wants to set up a telephone line at his farm. Unfortunately, the phone company is u ...
- scrapy 采集网页出现丢失url的问题
url_list = ["http://www.icoat.cc/news/list_18_3.html", "http://www.icoat.cc/news/list ...
- [吴恩达机器学习笔记]12支持向量机5SVM参数细节
12.支持向量机 觉得有用的话,欢迎一起讨论相互学习~Follow Me 参考资料 斯坦福大学 2014 机器学习教程中文笔记 by 黄海广 12.5 SVM参数细节 标记点选取 标记点(landma ...
- [DeeplearningAI笔记]卷积神经网络3.10候选区域region proposals与R-CNN
4.3目标检测 觉得有用的话,欢迎一起讨论相互学习~Follow Me 3.10 region proposals候选区域与R-CNN 基于滑动窗口的目标检测算法将原始图片分割成小的样本图片,并传入分 ...
- [DeeplearningAI笔记]卷积神经网络1.6-1.7构造多通道卷积神经网络
4.1卷积神经网络 觉得有用的话,欢迎一起讨论相互学习~Follow Me 1.6多通道卷积 原理 对于一个多通道的卷积操作,可以将卷积核设置为一个立方体,则其从左上角开始向右移动然后向下移动,这里设 ...
- Ubuntu 14.04.3 window10双系统情遇到'Disconnected: You are now offline'问题
笔电是win10系统,单独开除50G做了一个Ubuntu系统,安装的是14.04.03版本,安装成功后,发现wifi连接不上,选择wifi并输入密码后提示:“Disconnected: You are ...
- springsecurity remember-me 功能
本文基于spring-security-web-4.1.2.RELEASE. 要实现rememberMe,有两种方案. 1.基于简单加密token的方法 首先需要在配置文件中加入<remembe ...
- Integer Numbers
ZOJ Problem Set - 3365 Integer Numbers Time Limit: 1 Second Memory Limit: 32768 KB Special ...
- python 常用模块之ConfigParser
在程序中使用配置文件来灵活的配置一些参数是一件很常见的事情,配置文件的解析并不复杂,在Python里更是如此,在官方发布的库中就包含有做这件事情的库,那就是ConfigParser, Python C ...
- LintCode 539: Move Zeroes
终于下决心开始刷题了! 选择LintCode而不是LeetCode主要是因为LintCode操作更顺手,希望能够坚持下去. 还是循序渐进吧,数据结构和算法的东西很久没碰都很生疏了,先找找感觉. 这是一 ...