网站大量收购闲置独家精品文档,联系QQ:2885784924

数据结构chap007培训资料.ppt

  1. 1、本文档共83页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
数据结构chap007培训资料.ppt

嘉兴学院数学与信息工程学院;7.1 抽象数据类型图的定义;? 【重点和难点 】;? 【学习指南 】; ADT Graph {   数据对象: V是具有相同特性的数据元素的集合,称为顶点集。  数据关系:   VR={v,w| v,w∈V且P(v,w),v,w表示从v到w的弧,并称 v 为弧尾(或初始点),w 为弧头(或终端点),谓词P(v,w)定义了弧v,w的意义或信息 }; 由于“弧”是有方向的,因此称由顶点集和弧集构成的图为有向图。;若v, w?VR 必有w, v?VR,则称 (v,w) 为顶点v 和顶点 w 之间存在一条边。;; 假设图中有 n 个顶点,e 条边,则; 假若顶点v 和顶点w 之间存在一条边或弧,则称顶点v 和w 互为邻接点。;顶点v的出度: 以顶点v为弧尾的弧的数目;; 设图G=(V,{VR})中的一个顶点序列 { u=vi,0,vi,1, …, vi,m=w}中,(vi,j-1,vi,j)?VR 1≤j≤m, 则称从顶点u 到顶点w 之间存在一条路径。 路径上边的数目称作路径长度。; 若无向图G中任意两个顶点之间都有路径相通,则称此图为连通图;; 若任意两个顶点之间都存在一条有向路径,则称此有向图为强连通图。; 假设一个连通图有 n 个顶点和 e 条边,其中 n-1 条边和 n 个顶点构成一个极小连通子图,称该极小连通子图为此连通图的生成树。;结构的建立和销毁;CreatGraph(G, V, VR): // 按定义(V, VR) 构造图;对顶点的访问操作;对邻接点的操作;插入或删除顶点;插入和删除弧;遍 历;;Aij={; 每一行中“1”的个数为该顶点的出度; 每一列中1的个数为该顶点的入度。;#define INFINITY = INT_MAX;      // 最大值∞ #define MAX_VERTEX_NUM = 20;     // 最大顶点个数 typedef enum {DG, DN, AG, AN} GraphKind;   // 类型标志{有向图,有向网,无向图,无向网} ;typedef struct ArcCell { // 弧的定义 VRType adj; // VRType是顶点关系类型。 // 对无权图,用1或0表示相邻否; // 对带权图,则为权值类型。 InfoType *info; // 该弧相关信息的指针 } ArcCell, AdjMatrix[MAX_VERTEX_NUM] [MAX_VERTEX_NUM];;typedef struct { // 图的定义 VertexType // 顶点信息 vexs[MAX_VERTEX_NUM]; AdjMatrix arcs; // 邻接矩阵 int vexnum, arcnum; // 顶点数,弧数 GraphKind kind; // 图的种类标志 } MGraph;;0 A 1 4 1 B 0 4 5 2 C 3 5 3 D 2 5 4 E 0 1 5 F 1 2 3;有向图的邻接表;A;例1: 给出下图的邻接表和邻接矩阵:;例2(习题集P47/7.1): 给出以下有向图的 1)邻接矩阵 2)每个顶点的入/出度; 3)邻接表及逆邻接表 4)强连能分量;typedef struct ArcNode { int adjvex; // 该弧所指向的顶点的位置 struct ArcNode *nextarc; // 指向下一条弧的指针 InfoType *info; // 该弧相关信息的指针 }

文档评论(0)

youngyu0329 + 关注
实名认证
内容提供者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档