第7章图 72 图的存储结构.ppt

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

第7章 图 7.2 图的存储结构 7.2.1 邻接矩阵 int a[n][n] 1.无向图的邻接矩阵 1 如果(vi,vj)∈E A(i,j)= 0 其它 7.2.1 邻接矩阵 邻接矩阵的特点 (1) A(i,i)=0 1≤i≤n; (2) 无向图的邻接矩阵是对称的 A(i,j)=A(j,i) 1≤i≤n, 1≤j≤n; 存入上(下)三角形,需n(n+1)/2个单元; (3) 无向图的邻接矩阵的第i行(或第i列)非零元素的 个数正好是第i个顶点的度 TD(vi ); (4) 有向图的邻接矩阵一般不对称。 有向图需要n2个单元; (5) 有向图的邻接矩阵的 第i行非零元素的个数是第i个顶点的出度 OD(vi); 第j列非零元素的个数是第j个顶点的入度ID(vi); 7.2.1 邻接矩阵 int a[n][n] 3. 网(带权值的图)的邻接矩阵 wij i!=j 且 (vi,vj)∈E或vi,vj∈E A(i,j)= ∽ i!=j ,无边或弧 0 i==j , 对角线元素 3. 网(带权值的图)的邻接矩阵 0 20 30 ∞ ∞ ∞ 20 0 ∞ 40 ∞ ∞ 30 ∞ 0 50 ∞ ∞ ∞ 40 50 0 70 80 ∞ ∞ ∞ 70 0 ∞ ∞ ∞ ∞ 80 ∞ 0 ? 在主函数中应用 int main() { AdjMWGraph G0; G0.CreatG(4,5); G0.PrintOut(); _getch(); return 0; } 7.2.3 邻接链表 1. 顶点的结构 const int MaxVertices=100; typedef int VerT; //顶点数据类型 typedef int DistT; //边的数据类型 struct item { VerT data; //顶点数据 Edge *adj; //邻接边的指针 }; 2.数组(向量) item Vertices[MaxVertices]; //顶点的数组 7.2.3 邻接链表 3. 边的结构 struct Edge { int dest; //邻接顶点下标 DistT weight; //边的权值,或更多 Edge *next; //指针 }; 7.2.3 邻接链表 const int MaxVertices=100; typedef int VerT; typedef int DistT; struct item { VerT data; //顶点数据 Edge *adj; //邻接边的指针 }; item Vertices[MaxVertices]; //顶点的数组 在主函数中应用 int main() { AdjTWGraph G0; int n0,e0; cinn0e0; G0.CreatG(n0,e0); G0.PrintOut(); _getch(); return 0; } * * 2.有向图的邻接矩阵 1 如果vi,vj∈E A(i,j)= 0 其它 A1= A2= 4 5 6 2 1 3 20 30 40 50 70 80 const int MaxVertices=10; const

文档评论(0)

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

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

1亿VIP精品文档

相关文档