数据结构之--图(Graphics)
1.1:图的定义和术语
图是一种比线性表和树更为复杂的数据结构。在线性表中,数据元素之间仅有线性关系,每个元素仅有一个直接前驱和一个直接后继;在树形结构中,数据元素之间有着明显的层次关系,并且每一层上的数据元素可能和下一层中的多个元素,相关,但只能和上一层的一个元素相关,而在图形结构中,结点之间的关系可以是任意的,图中任意的两个元素之间都可能相关。
图是一种数据结构,再加上一组基本操作。
图的基本操作有
创建图(creatGraph),销毁图(destoryGraph),查找(searchNde),遍历(Traverse),添加结点(addNode)删除结点(deleteNode),图的遍历有深度优先遍历(DFSTraverse)和广度优先遍历(BFTraverse)
1.2图的存储结构
任何数据结构都能有两类不同的存储结构它们是不同的映像方式,(顺序映像和链式映像)因为图比较复杂,没有顺序映像的存储结构但可以借助数组的数据类型表示元素之间的关系,图常用的存储结构有邻接表,邻接多重表和十字链表。
邻接表是利用一个二维数组来表示图各元素之间的关系,具体定义如下所述,对于无向图当两个顶点(i,j)之间有边时可以将相应的aij置为1或者是 这点边的权值,而相反就将aij置为0或者是无穷大。这样一来我们就能用一个二维数据来表示图各元素之间的关系了。
下面给出图邻接矩阵的java实现代码
package neuq.chao;
import java.util.Scanner;
class GraphMatrix{
static final int MaxNum = 20;
static final int MaxValue = 65535;
char[] Vertex = new char[MaxNum]; //存储结点的信息
int GType; //图的类型0为无向图1表示有向图
int VertexNum; //结点的个数
int EdgeNum; //边的个数
int[][]EdgeWeight = new int[MaxNum+1][MaxNum+1];
int [] isTrav= new int[MaxNum];
}
public class Graph {
static Scanner input = new Scanner(System.in);
static void CreatGraph(GraphMatrix GM){
int i,j,k;
int weight;
char EstartV,EendV; System.out.printf("输入图的各顶点信息");
for(i=0;i<GM.VertexNum;i++){
System.out.printf("第%d个顶点:",i+1);
GM.Vertex[i] = (input.next().toCharArray())[0];
}
System.out.printf("输入各边的顶点及权值:\n");
for(k=0;k<GM.EdgeNum;k++){
System.out.printf("第%d条边:",k+1);
EstartV = input.next().charAt(0);
EendV = input.next().charAt(0);
weight = input.nextInt();
for(i=0;EstartV!=GM.Vertex[i];i++);
for(j=0;EendV!=GM.Vertex[j];j++);
GM.EdgeWeight[i][j] = weight;
if(GM.GType==0){ //无向图
GM.EdgeWeight[j][i]=weight;
} }
}
static void ClearGraph(GraphMatrix GM){
//清空图
int i,j;
for(i=0;i<GM.VertexNum;i++){
for(j=0;j<GM.VertexNum;j++){
GM.EdgeWeight[i][j]=GraphMatrix.MaxValue; }
}
System.out.println(GM.VertexNum);
}
static void OutGraph(GraphMatrix GM){
int i,j;
for(j=0;j<GM.VertexNum;j++){
System.out.printf("\t%c",GM.Vertex[j]);
}
System.out.printf("\n");
for(i=0;i<GM.VertexNum;i++){
System.out.printf("%c",GM.Vertex[i]);
for(j=0;j<GM.VertexNum;j++){
if(GM.EdgeWeight[i][j]==GraphMatrix.MaxValue){
System.out.printf("\tZ");
}
else{
System.out.printf("\t%d",GM.EdgeWeight[i][j]);
}
}
System.out.printf("\n");
}
}
static void DeepTraOne(GraphMatrix GM,int n){//从第n个结点开始,深度遍历图
int i;
GM.isTrav[n] = 1;
System.out.printf("->%c",GM.Vertex[n]);
//添加处理结点的操作
for(i=0;i<GM.VertexNum;i++){
if(GM.EdgeWeight[n][i]!=GraphMatrix.MaxValue&&GM.isTrav[n]==0){
DeepTraOne(GM,i);
}
}
}
static void DeepTraGraph(GraphMatrix GM){
//深度优先遍历
int i;
for(i=0;i<GM.VertexNum;i++){
GM.isTrav[i]=0;
}
System.out.printf("深度优先遍历结点");
for(i=0;i<GM.VertexNum;i++){
if(GM.isTrav[i]==0){
DeepTraOne(GM,i);
}
}
System.out.printf("\n");
}
public static void main(String args[]){
GraphMatrix GM=new GraphMatrix(); System.out.printf("输入生成图的类型");
GM.GType = input.nextInt();
System.out.printf("输入图的顶点数量:");
GM.VertexNum = input.nextInt();
System.out.print(GM.VertexNum);
System.out.printf("输入图的边数量:");
GM.EdgeNum=input.nextInt(); CreatGraph(GM); System.out.printf("该图的邻接矩阵的数据如下:\n");
OutGraph(GM);
DeepTraGraph(GM);
ClearGraph(GM);
}
}
数据结构之--图(Graphics)的更多相关文章
- python数据结构之图的实现
python数据结构之图的实现,官方有一篇文章介绍,http://www.python.org/doc/essays/graphs.html 下面简要的介绍下: 比如有这么一张图: A -> B ...
- hdu 1233:还是畅通工程(数据结构,图,最小生成树,普里姆(Prim)算法)
还是畅通工程 Time Limit : 4000/2000ms (Java/Other) Memory Limit : 65536/32768K (Java/Other) Total Submis ...
- 利用python+graphviz绘制数据结构关系图和指定目录下头文件包含关系图
作为一名linux系统下的C语言开发,日常工作中经常遇到两个问题: 一是分析代码过程中,各种数据结构互相关联,只通过代码很难理清系统中所有结构体的整体架构,影响代码消化的效率; 二是多层头文件嵌套包含 ...
- python数据结构之图的实现方法
python数据结构之图的实现方法 本文实例讲述了python数据结构之图的实现方法.分享给大家供大家参考.具体如下: 下面简要的介绍下: 比如有这么一张图: A -> B A ...
- python数据结构之图深度优先和广度优先实例详解
本文实例讲述了python数据结构之图深度优先和广度优先用法.分享给大家供大家参考.具体如下: 首先有一个概念:回溯 回溯法(探索与回溯法)是一种选优搜索法,按选优条件向前搜索,以达到目标.但当探索到 ...
- 数据结构之图 Part2 - 1
邻接矩阵 网上很少有C# 写图的数据结构的例子,实际的项目中也从来没用过Array 这坨东西,随手写个,勿喷. namespace LH.GraphConsole { public struct Gr ...
- 数据结构之图 Part1
Part 1 预计使用7天的时间来过掉图相关的数据结构.第一天主要是一天图的基本概念,熟练掌握定义是一切交流和沟通的基础. 1定义 1.1图 有穷非空顶点,外加边. G(V,E) Graph Vert ...
- C++数据结构之图
图的实现是一件很麻烦的事情,很多同学可能在学数据结构时只是理解了图的基本操作和遍历原理,但并没有动手实践过.在此,我说说我的实现过程. 首先,在草稿纸上画一个图表,这里是有向图,无向图也一样,如下: ...
- 【js数据结构】图的深度优先搜索与广度优先搜索
图类的构建 function Graph(v) {this.vertices = v;this.edges = 0;this.adj = []; for (var i = 0; i < this ...
随机推荐
- python之错题巩固
.#把班级学⽣数学考试成绩录⼊到⼀个列表中: 并求平均值. 要求: 录⼊的时候 # 要带着⼈名录⼊, 例如: 张三_44 li = [] : str_input = input('请输入你的姓名和分数 ...
- CocoaPods 提交自己的库
今想把自己写的一个view提交到CocoaPods时候,突然发现pull request被拒了,原来从去年开始就改用trunk了... 网上那些folk 在提交的pull request的教程都不可用 ...
- ACM学习大纲(转)
1 推荐题库 •http://ace.delos.com/usaco/ 美国的OI 题库,如果是刚入门的新手,可以尝试先把它刷通,能够学到几乎全部的基础算法极其优化,全部的题解及标程还有题目翻译可以b ...
- Y2分班考试 笔试题总结
1. 此题编译错误 base无法点出methodB()方法 2. 第二题选C 3.此题选D:正确的输出级别为fatal>error>warn>info>debug 4. 此题 ...
- Java方式配置Spring MVC
概述 使用Java方式配置Spring MVC,以及回顾一下Spring MVC的各种用法. Spring MVC简述 关于Spring MVC的介绍网上有很多,这里就不再赘述了,只是要说一下,Spr ...
- SpringBoot 2.x (10):整合Redis
Redis部署到阿里云: 下载redis源码,编译,允许远程访问的配置 阿里云安全组设置: SSH连过去: wget http://download.redis.io/releases/redis-4 ...
- StarUML安装与Win7不兼容解决
最近在学习建模工具(StarUML)发现 其他功能一切正常 但是无法显示代码导出功能, 正常界面如下: 我的安装确没有导出功能缺少C++,C# ,Java等导出功能 解决办法: 到StarUM ...
- 在PaaS上开发Web、移动应用(2)
在PaaS上开发Web.移动应用(2) PaaS学习笔记目录 PaaS基础学习(1) 在PaaS上开发Web.移动应用(2) PaaS优点与限制(3) 6. 巨型代码,是指持续不断地向一个应用程序添加 ...
- Android ScrollView嵌套RecyclerView导致在三星s8曲面屏显示不全问题
当RecyclerView适配显示不全时可以单独给其嵌套一个相对布局!!!(必须是相对布局),这样在曲面屏手机就可以全部显示出来如下图所示 <RelativeLayout android:lay ...
- uvm_misc——杂货铺(miscellaneous)
uvm_misc 是个很有意思的文件夹,本质上就是个UVM的杂货铺,包含一些很重要的class, task, function, 但不知道给归类到哪儿,所以,uvm_misc就很好地承担了这个任务,几 ...