图的建立与输出
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
数据结构课程设计
目录
一、需求分析 (1)
二、概要设计 (1)
三、算法设计的思想 (2)
邻接矩阵表示法 (2)
四、算法的流程图 (3)
五、算法设计分析 (4)
5.1无向网邻接矩阵的建立算法 (4)
5.2无向图邻接矩阵的建立算法 (4)
六、源代码 (5)
七、调试测试 (11)
八、总结 (14)
一、需求分析
问题重述:
建立图的存储结构(图的类型可以是有向图、无向图),能够输入图的顶点和边的信息,并存储到相应存储结构中,而后输出图的邻接矩阵。
应用环境设定给定某类图的顶点和边的相关信息,要求输出该图的邻接矩阵。
用户界面命令行界面,用户选择所要建立的图的类型,输入相关顶点和边的信息,
然后输出该图的邻接矩阵。
输入方式首先输入所要建立的图形类型的代码,然后输入顶点vexnum和边的数
量arcnum,再输入顶点信息,边的2个端点v1和v2,如果建立的是网则还要输
入权值w。
输出方式输出的是一个邻接矩阵,采用for循环嵌套,输出该图的邻接矩阵。
数据存储方式全部在内存存放,不使用硬盘上的文件或其他数据源,程序执行过
程中和结束后不保存数据。
程序功能
1. 输入图的类型;
2. 输入相应的图的顶点和边的相关信息;
3. 得到图的邻接矩阵。
二、概要设计
基本操作:
CreateGraph(MGraph &G)
初始条件:图G未创建。
操作结果:创建一个图G。
CreateUDG(MGraph &G);
初始条件:无向图G未创建。
操作结果:创建一个无向图并求出其邻接矩阵。
CreateDG(MGraph &G);
初始条件:有向图G未创建。
操作结果:创建一个有向图并求出其邻接矩阵。
CreateDN(MGraph &G);
初始条件:有向网G未创建。
操作结果:创建一个有向网并求出其邻接矩阵。
CreateUDN(MGraph &G);
初始条件:有无向网G未创建。
操作结果:创建一个无向网并求出其邻接矩阵。
Display(MGraph G)
。初始条件:图G已创建。
操作结果:输出图G的邻接矩阵。
三、算法设计的思想
邻接矩阵表示法:
设G=(V,E)是一个图,其中V={V1,V2,V3…,Vn}。G的邻接矩阵是一个具有下述性质的n阶方阵:若(Vi,Vj)∈E或者
图5-2中有向图G1和无向图G2的邻接矩阵分别为M1和M2:
M1=┌0 1 0 1 ┐
│ 1 0 1 0 │
│ 1 0 0 1 │
└0 0 0 0 ┘
M2=┌0 1 1 1 ┐
│ 1 0 1 0 │
│ 1 1 0 1 │
└ 1 0 1 0 ┘
注意无向图的邻接是一个对称矩阵,例如M2。
用邻接矩阵表示法来表示一个具有n个顶点的图时,除了用邻接矩阵中的n*n个元素存储顶点间相邻关系外,往往还需要另设一个向量存储n个顶点的信息。因此其类型定义如下:
VertexType vertex[MAX_VERTEX_NUM]; // 顶点向量
AdjMatrix arcs; // 邻接矩阵
int vexnum, arcnum; // 图的当前顶点数和弧(边)数
GraphKind kind; // 图的种类标志
若图中每个顶点只含一个编号i(1≤i≤vnum),则只需一个二维数组表示图的邻接矩阵。此时存储结构可简单说明如下:
type adjmatrix=array[1..vnum,1..vnum]of adj;
利用邻接矩阵很容易判定任意两个顶点之间是否有边(或弧)相联,并容易求得各个顶点的度。
对于无向图,顶点Vi的度是邻接矩阵中第i行元素之和,即
n
D(Vi)=∑A[i,j]
j=1
对于有向图,顶点Vi的出度OD(Vi)为邻接矩阵第i行元素之和,顶点Vi 的入度ID(Vi)为第i列元素之和。即
n n
OD(Vi)=∑A[i,j],ID(Vi)=∑A[j,i])
j=1j=1
用邻接矩阵也可以表示带权图,只要令
Wij, 若(Vi,Vj)∈或者
0 , 否则。
四、算法的流程图
主程序流程图图的构造流程图
五、算法设计分析
1、无向图邻接矩阵的建立算法如下:
procedure build-graph; {建立无向图的邻接矩阵}
begin
for i:=1 to n do read(G.vertex[i]);{读入n个顶点的信息}
for i:=1 to n do
for j:=1 to e do
G.arcs[i][j] =0;
{将邻接矩阵的每个元素初始化成0 }
for k:=1 to e do {e为边的数目}
[ read(i,j,w) {读入边和权}G.arcs[i][j]:=w]
G.arcs[i][j]=G.arcs[i][i]{置对称弧}
end;
该算法的执行时间是O(n+n2+e),其中消耗在邻接矩阵初始化操作上的时间是O(n2),而e 2、有向图邻接矩阵的建立算法如下: procedure build-graph; {建立有向图的邻接矩阵} begin for i:=1 to n do read(G.vertex[i]);{读入n个顶点的信息} for i:=1 to n do for j:=1 to e do G.arcs[i][j] =0; {将邻接矩阵的每个元素初始化成0 } for k:=1 to e do {e为边的数目} [ read(i,j,w) {读入边和权}G.arcs[i][j]:=w] G.arcs[i][j]=G.arcs[i][i]{置对称弧} end; 该算法的执行时间是O(n+n2+e),其中消耗在邻接矩阵初始化操作上的时间是O(n2),而e