《数据结构六章》PPT课件.ppt
《《数据结构六章》PPT课件.ppt》由会员分享,可在线阅读,更多相关《《数据结构六章》PPT课件.ppt(59页珍藏版)》请在三一办公上搜索。
1、第六章 图,6.1 图的概念图(Graph)是一种结点之间为多对多关系的数据结构。逻辑特征是:可以有任意个开始结点和任意个终端结点,其余各个结点可以有任意个前趋和任意个后继。图中的结点常称为顶点。图的逻辑结构可以用二元组表示:Graph(V,E)V是顶点(vertex)的集合;E是边(edge)的集合。,有向图(Digraph)若图G中的每条边都是有方向的,则称图G为有向图。,例,G1=(V1,E1)V1=v1,v2,v3E1=,G2=(V2,E2)V2=v1,v2,v3E2=,无向图(Undigraph)若图G中的每条边都是没有方向的,则图G称为无向图。,例,G3=(V3,E3)V3=v1,
2、v2,v3,v4E3=(v1,v2),(v1,v3),(v1,v4),(v2,v3),(v2,v4)G4=(V4,E4)V4=v1,v2,v3 E4=(v1,v2),(v1,v3),(v2,v3),顶点的度有向图中,顶点的度分成入度与出度入度:该顶点入边的数目出度:该顶点出边的数目无向图中,顶点的度为与该顶点相连的边数,邻接点与关联边有向图中,若是有向图中的一条边,则顶点x 和顶点y称为邻接点。称x邻接到y或y邻 接于x,同时称边是顶点x和顶点y 相关联的边(Incident);无向图中,若(x,y)是无向图中的一条边,则顶点 x和顶点y互为邻接点,并且称边(x,y)是 顶点 x和顶点y相关联
3、的边。,子图设有图G=(V,E),如果满足:VVEEE中边所邻接的点均在V中出现 则 G=(V,E)也是一个图,并且称之为G的子图。有向完全图n个顶点的有向图最大边数是n(n-1)无向完全图n个顶点的无向图最大边数是n(n-1)/2路径有向图G=(V,E)中,若存在一个顶点序列vp,vi1,vi2,vin,vq,使得,均是图中的边,则称此序列是从顶点vp到vq一条路径。路径长度该路径上经过边的数目。回路一条路径第一个顶点和最后一个顶点相同的 叫简单路径序列中顶点不重复出现的路径叫简单回路除了第一个顶点和最后一个顶点外,其余顶点不重复出现的回路叫,有根图若存在一个顶点v,从该顶点到其余各个顶点都
4、有路径,则称此图为有根图 连通从顶点x到顶点y有一条路径,则说x和y是连通的连通图图中任意两个顶点都是连通的叫连通图连通分量无向图G的极大连通子图称为G的连通分量 强连通图若G中任意两个顶点都是强连通的,则称图G是强连通图 强连通分量 有向图G的极大强连通子图称为G的强连通分量 权与图的边相关的数值叫权值。网络边上带权的图称为网络,6.2 图的存储结构邻接矩阵表示顶点之间邻接关系的矩阵 设G=(V,E)是具有n个顶点的图,则G的邻接矩阵是一个n阶方阵A,A中元素的值aij可以定义为:,特点:无向图的邻接矩阵对称;有n个顶点的无向图需存储空间为n 有向图邻接矩阵不一定对称;有n个顶点的有向图需存
5、储空间为n无向图中顶点Vi的度是邻接矩阵A中第i行元素之和有向图中,顶点Vi的出度是A中第i行元素之和顶点Vi的入度是A中第i列元素之和网的邻接矩阵可定义为:,可以得到邻接矩阵存储结构C语言描述如下:#define n 5/*图的顶点数*/#define e 6/*图的边数*/#define max 10000/*设置一个极大数无穷大*/typedef char vextype;/*顶点类型*/typedef int adjtype;/*权值类型*/typedef structvextype vertexn+1;/*顶点数组*/adjtype edgen+1n+1;/*邻接矩阵*/adj_ma
6、trix;,邻接表邻接表法(Adjacency List)是图的一种链式存储结构,顶点采用顺序方式进行存储,用n个单链表来存储图中的边,第i个单链表是所有与第i个顶点相关联的边链接而成的,称此单链表为第i个顶点的边表,边表中的每个结点称为边表结点。在顶点的顺序表中,每个元素增加一个指针域用来存放各个边表的头指针,称此顺序表为顶点表,而顺序表中的每个元素称为顶点表结点。顶点表和各顶点的边表一起组成图的邻接表。,邻接表存储结构C语言描述如下:typedef struct node int adjvex;/*邻接点域*/struct node*next;/*指针域*/edgenode;/*定义边表结
7、点*/typedef struct vextype vertex;/*顶点域*/edgenode*link;/*指针域*/vexnode;/*定义顶点表结点*/vexnode adjlistn+1;,特点无向图中顶点Vi的度为第i个单链表中的结点数有向图中顶点Vi的出度为第i个单链表中的结点个数顶点Vi的入度为整个单链表中邻接点域值是i的结点个数逆邻接表:有向图中对每个结点建立以Vi终点的单链表,边集数组(edgeset array)是图的一种顺序存储方式,利用一维数组来存储图中所有的边,数组中的每个元素用来存储图中的一条边,包括:始点、终点的序号及权值,该数组中所含元素的个数要大于等于图中边
8、的条数。,边集数组邻接表法(Adjacency List)是图的一种链式存储结构,typedef struct edge int fromvex;/*边的始点域*/int endvex;/*边的终点域*/int weight;/*边的权值域*/edgeset;/*定义边集数组类型*/edgeset gee+1;/*边集数组全局量*/,6.3 图的遍历深度优先遍历(DFS)方法:对于给定的图G,假设初始时所有顶点均未被访问过,则可从G中任选一顶点vi做为初始出发点,深度优先搜索可定义为:访问出发点vi,置访问标记为1,然后依次从vi的未被访问过的邻接点vj出发,继续进行深度优先搜索,直至图中所有
9、和vi有路径相通的顶点均被访问过。很显然图的深度优先搜索过程是递归的。它的特点是尽可能先对图从纵深方向进行搜索,故称为深度优先搜索。,DFS序列为:v1,v2,v4,v8,v5,v3,v6,v7。,深度优先遍历算法递归算法,void DFS(int i)int j;printf(输出序号为%d的顶点:%cn,i,adj-vertexi);visitedi=1;/*标记vi已经访问过*/for(j=1;jedgeij),void DFSL(int i)edgenode*p;printf(输出序号为%d的顶点:%cn,i,adjlisti.vertex);visited i=1;/*标记vi已经访
10、问过*/p=adjlisti.link;/*p为vi的边表头指针*/while(p)/*依次搜索vi的邻接点*/if(!visitedp-adjvex)DFSL(p-adjvex);p=p-next;,在邻接矩阵上实现遍历的过程:,生成树,连通图G的一个子图如果是一棵包含G的所有顶点的树,则该子图称为G的生成树(Spanning Tree)。,广度优先遍历(BFS)方法:对于给定图G,假设初始时的所有顶点均未被访问过,从图G中任选一顶点vi为初始出发点,广度优先搜索遍历可定义为:首先访问出发点vi,接着依次访问vi的所有的邻接的未被访问过的点w1,w2,wt,然后,再依次访问与w1,w2,wt
11、相邻接的未被访问过的顶点。依此类推,直至图中所有和初始出发点vi有路径相通的顶点都已访问到为止。显然,此方法的特点是尽可能先对横向进行搜索,故称之为广度优先搜索。,BFS序列为:v1,v2,v3,v4,v5,v6,v7,v8,广度优先遍历算法,在广度优先遍历中,先被访问的顶点,其邻接点亦先被访问,所以在算法的实现中需要使用一个队列,用来依次记住被访问过的顶点。算法开始时,将初始点Vi访问后插入队列中,以后每从队列中删除一个元素,就依次访问它的每一个未被访问过的邻接点,并令其进队。这样当队列为空时,表明所有与初始点有路径相通的顶点都已访问完毕,算法到此结束。,邻接表法广度优先:void BFSL
12、(int k)/*用adjlist存储*/int i;edgenode*p;SETNULL(Q);printf(输出序号为%d的顶点:%cn,k,adjlistk.vertex);/*访问出发点vk*/visitedk=1;/*标记vk已经访问过*/ENQUEUE(Q,k);/*顶点vk的序号k入队*/while(!EMPTY(Q)/*队列非空执行*/i=DEQUEUE(Q);/*队头元素顶点序号出队*/p=adjlisti.link;while(p!=NULL)if(!visitedp-adjvex)printf(输出序号为%d的顶点:%cn,p-adjvex,adjlistp-adjvex
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 数据结构六章 数据结构 PPT 课件
![提示](https://www.31ppt.com/images/bang_tan.gif)
链接地址:https://www.31ppt.com/p-5519662.html