C语言数据结构基础学习笔记——图
图(G)由顶点集(V)和边集(E)组成,G=(V,E)
常用概念:
①V(G)表示图G中顶点的有限非空集,V永不为空;
②用|V|表示图G中顶点的个数,也称为图G的阶;
③E(G)表示图G中顶点之间关系(边)的集合;
④用|E|表示图G中边的条数。
图分为:
①有向图:有向边(弧)的有限集合<V,W>;
②无向图:无向边(边)的有限集合(V,W)。
简单图:不存在顶点到自身的边,同一条边不重复出现。
多重图:某两个结点之间的边数多于一条,又允许顶点通过一条边和自己关联。
完全图:任意两个结点之间都有边,其分为:
①无向完全图:如果任意两个顶点之间都有边,其有n个结点,n*(n-1)/2条边;
②有向完全图:如果任意两个顶点之间都存在方向相反的两条弧,其有n个结点,n*(n-1)条边。
子图:若G=(V,E),G'=(V',E'),其中V'为V的子集,E'为E的子集,若V(G')=V(G),则G'为G的子图。
连通图:图中任意两个顶点都是连通的。
连通分量:无向图中的极大连通子图,有以下特点:①子图;②连通;③顶点足够多;④包含这些依附在顶点的所有边。
强连通:顶点V到顶点W和顶点W到顶点V都有路径。
强连通图:图中任意一对顶点都是强连通的。
强连通分量:有向图中的极大强连通子图,有以下特点:①子图;②强连通;③顶点足够多;④包含这些依附在顶点的所有弧。
度:以该顶点为一个端点的边数目。
在无向图中:顶点V的度是依附于该顶点的边条数,记为TD;
在有向图中:①入度:以顶点V为终点的有向边的条数,记为ID;
②出度:以顶点V为起点的有向边的条数,记为OD。
图的存储结构有以下几种:
①图的顺序存储结构:邻接矩阵,其顶点用一位数组来存储,边或弧用二维数组来存储,例如a[i][j]=1表示(vi,vj)或<vi,vj>是图的边。
#define MaxVertexNum 100 //顶点数目最大值
typedef char VertexType; //顶点的数据类型
typedef int EdgeType; //整数表示权值或者连通性
typedef struct{
VertexType Vex[MaxVertexNum]; //顶点表
EdgeType Edge[MaxVertexNum][MaxVertexNum]; //邻接矩阵,边表
int vexnum,arcnum; //图的当前顶点数和弧度
}MGraph;
②图的链式存储结构:邻接表,由顶点表和边表(单链表)组成,无法遍历,只有出弧。
#define MaxVertexNum 100
typedef struct VNode{ //顶点表结点
VertexType data; //顶点表信息
ArcNode *firstedge; //单链表头指针
}VNode,AdjList[MaxVertexNum];
typedef struct ArcNode{ //边表结点
int adjvex; //该弧所指向顶点的位置
struct ArcNode *next; //指向下一条弧的指针
}ArcNode;
typedef struct{
AdjList vertices; //邻接表
int vexnum,arcnum; //图的顶点数和弧数
}ALGraph; //以邻接表存储的图类型
③有向图的优化链式存储结构:十字链表
#define MaxVertexNum 100
typedef struct VNode{
VertexType data; //顶点数据
ArcNode *first,*firstout; //该顶点的入边表头指针和出边表头指针
}VNode;
typedef struct ArcNode{
int tailvex,headvex; //这条弧的起点所在顶点表下标和终点所在顶点表下标
struct ArcNode *hlink,*tlink; //终点相同的下一条弧以及起点相同的下一条弧
}ArcNode;
typedef struct{
VNode xlist[MaxVertexNum]; //顶点依旧用顺序存储
int vexnum,arcnum; //图的顶点数与弧数
}GLGraph; //十字链表存储的图类型
④无向图的优化链式存储结构:邻接多重表
#define MaxVertexNum 100
typedef struct VNode{ //顶点表结点
VertexType data; //顶点表信息
ArcNode *firstedge; //单链表头指针
}VNode;
typedef struct ArcNode{ //边表结点
int ivex,jvex; //这条边依附的两个顶点在顶点表的下标
struct ArcNode *ilink,*jlink; //对应两个顶点的下一条边
}ArcNode;
typedef struct{
VNode xlist[MaxVertexNum];
int vexnum,arcnum; //图的顶点数和弧数
}DLGraph;
图的遍历:因为图的顶点没有特殊性,所以可以设置一个访问数组,记录遍历过程中访问过的顶点。
广度优先遍历(BFS):类似于树中的层序遍历算法。
#define MaxSize 100
bool visited[MaxSize];
void BFS(Graph G,int v){
ArcNode *p; //工作指针p
InitQueue(Q); //初始化第一个队列
visit(v); //访问第一个顶点v
visited[v]=true; //对v做已访问标记
Enqueue(Q,v); //顶点v入队列
while(!isEmpty(Q)){ //只要队列不空
DeQueue(Q,v); //顶点v出队列
p=G->adjlist[v].firstedge; //指针p指向当前顶点的边表链表头指针
while(p){
if(!visited[p->adjvex]){ //p所指向顶点如果未被访问
visit(p->adjvex); //访问p所指向的顶点
visited[p->adjvex]=true; //对这个顶点做已访问标记
EnQueue(Q,p->adjvex); //这个顶点入队列
}
p=p->next; //p指向该顶点的下一条边
}
}
}
void BFSTraverse(Graph G){
int i; //单独定义是方便多个循环使用
for(i=;i<G->vexnum;i++) visited[i]=false; //将标志数组初始化(全局数组)
for(i=;i<G->vexnum;i++){
if(!visited[i]) BFS(G,i); //为避免非连通图一些顶点访问不到,若是连通图只会执行一次
}
}
BFS的应用:解决单源非带权图最短路径问题。
深度优先遍历(DFS):类似于树的先序遍历算法。
#define MaxSize 100
bool visited[MaxSize];
void DFS(Graph G,int v){
ArcNode *p;
visit(v);
visited[v]=true;
p=G->adjlist[v].firstarc;
while(p!=NULL){
if(!visited[p->adjvex]){
DFS(G,p->adjvex);
}
p=p->nextarc;
}
}
void DFSTraverse(Graph G){
int i;
for(i=;i<G->vexnum;i++) visited[i]=false; //将标志数组初始化(全局数组)
for(i=;i<G->vexnum;i++){
if(!visited[i]) DFS(G,i);
}
}
C语言数据结构基础学习笔记——图的更多相关文章
- C语言数据结构基础学习笔记——C语言基础
抽象数据类型(ADT)是指一个数学模型以及定义在该模型上的一组操作,通常用(数据对象,数据关系,基本操作集)这样的三元组来表示抽象数据类型. 数据结构是相互之间存在一种或多种特定关系的数据元素的集合, ...
- C语言数据结构基础学习笔记——B树
2-3树:是一种多路查找树,包含2结点和3结点两种结点,其所有叶子结点都在同一层次. 2结点:包含一个关键字和两个孩子(或没有孩子),其左孩子的值小于该结点,右孩子的值大于该结点. 3结点:包含两个关 ...
- C语言数据结构基础学习笔记——树
树是一种一对多的逻辑结构,树的子树之间没有关系. 度:结点拥有的子树数量. 树的度:树中所有结点的度的最大值. 结点的深度:从根开始,自顶向下计数. 结点的高度:从叶结点开始,自底向上计数. 树的性质 ...
- C语言数据结构基础学习笔记——栈和队列
之前我们学过了普通的线性表,接下来我们来了解一下两种特殊的线性表——栈和队列. 栈是只允许在一端进行插入或删除的线性表. 栈的顺序存储结构也叫作顺序栈,对于栈顶指针top,当栈为空栈时,top=-1: ...
- C语言数据结构基础学习笔记——动态查找表
动态查找表包括二叉排序树和二叉平衡树. 二叉排序树:也叫二叉搜索树,它或是一颗空树,或是具有以下性质的二叉树: ①若左子树不空,则左子树上所有结点的值均小于它的根结点的值: ②若右子树不空,则右子树上 ...
- C语言数据结构基础学习笔记——静态查找表
查找:在数据集合中寻找满足某种条件的数据元素的过程称为查找. 查找表:用于查找的数据集合称为查找表,一般有以下操作:①查找是否在表中:②查找属性:③进行操作. 查找表又分为: ①静态查找表:只可以进行 ...
- C语言数据结构基础学习笔记——基础线性表
线性表是指具有相同数据类型的n(n>=0)个数据元素的有限序列,它具有一个表头元素和一个表尾元素,并且每一个数据元素最多只有一个直接前驱和一个直接后继. 线性表的顺序存储也叫作顺序表,它的特性是 ...
- 尚学堂JAVA基础学习笔记
目录 尚学堂JAVA基础学习笔记 写在前面 第1章 JAVA入门 第2章 数据类型和运算符 第3章 控制语句 第4章 Java面向对象基础 1. 面向对象基础 2. 面向对象的内存分析 3. 构造方法 ...
- R语言与机器学习学习笔记
人工神经网络(ANN),简称神经网络,是一种模仿生物神经网络的结构和功能的数学模型或计算模型.神经网络由大量的人工神经元联结进行计算.大多数情况下人工神经网络能在外界信息的基础上改变内部结构,是一种自 ...
随机推荐
- python标准库之random模块
Python中的random模块用于生成随机数. 下面具体介绍random模块的功能: 1.random.random() #用于生成一个0到1的 随机浮点数:0<= n < 1.0 1 ...
- E-R视图中有关图形的用法
这里先推荐几款相对好用的画E-R图的软件: 第一款为: 这是一款在线的画流程图软件 第二款为:亿图图示 第三款为:Visio ER图是在设计数据库之前,明白数据之间的相互关系,理清数据之间的逻辑而需 ...
- 什么是C/S模式与B/S模式,两者区别与优缺点
转自https://wenwen.sogou.com/z/q1709598292.htm C/S (Client/Server,客户机/服务器)模式又称C/S结构,是软件系统体系结构的一种.C/S模式 ...
- JAVA IO流 InputStream流 Read方法
read()首先我们来看这个没有参数的read方法,从(来源)输入流中(读取的内容)读取数据的下一个字节到(去处)java程序内部中,返回值为0到255的int类型的值,返回值为字符的ACSII值(如 ...
- python学习线路
第一章:计算机基础 https://www.cnblogs.com/koukouku/p/10646025.html 1.1 计算机认识 1.2操作系统 1.3 计算机的运算(进制) 1.4解释器/编 ...
- 复习下CSS-零碎要点
一,CSS选择器 1. h1 > strong {color:red;}表示的是只有h1下子元素才是红色,“孙子”就不行. 2. h1 + p {margin-top:50px;} 选择 ...
- Ubuntu使用总结一
一.安装 Ubuntu桌面版与服务器版的不同之处桌面版面向个人电脑使用者,可以进行文字处理.网页浏览.多媒体播放和玩游戏.本质上说,这是一 个为普通用户所定制的多用途操作系统.另一方面,服务器版旨在充 ...
- 安装grub到U盘分区,实现多系统引导
目录 1.分区工具及分区类型 1.1 显示分区表和分区信息 1.1.1 fdisk -l 1.1.2 gdisk -l 1.1.3 parted -l 1.2 常见分区类型 1.3 分区样例 1.3. ...
- jenkins中shell脚本编写的两个注意点
在jenkins的build中,如果用shell脚本的话,要记住有两个地方要注意 1.由于默认jenkins是使用/bin/bash -xe xxx.sh来调用脚本的,所以不同于日常写的脚本,任何一行 ...
- Mysql 8.0 导入txt文件操作(课程实验)
一.实验准备: 1.实验设备:Dell laptop 7559; 2.实验环境:windows 10操作系统; 3.数据库版本:mysql 8.0; 二.实验目的: 1.将一个宠物表pet.txt文件 ...