创建图:包括建立结点的函数CreatVex(Graph *G),以及GreatUDG(Graph *G) ,GreatUDN(Graph *G) ,GreatDG(Graph *G) GreatDN(Graph *G) 1提示用户输入图的基本信息:顶点数,边数以及图的基本类型; 2通过for循环语句提示用户输入顶点的值; 3图Graph结构体类型包括:AdjList用来存储头结点的数组;int类型vexnum和arcnum,用来表示顶点数和边数的变量;int类型kind,用来存储图的类型。边ArcNode结构包括:adjvex,ArcNode *nextarc,int info前者表示指向的结点的下标,后者表示指向结点的下一条边结点,最后的变量为边所带的权值信息; 4根据图的类型决定是否要使用边中的info变量; 5提示用户按照正确的形式输入边的端点以及边上的权值信息; 遍历图:包括DFSTraverse(Graph G,VertexType vex)以及DFS(Graph G,int v)两个主要的便历函数。前者第二个参数表示开始进行便历的顶点,后者的第二个参数表示对图的下标为v的顶点访问。 1遍历前首先建立一个标志数组Visited[],长度为图中结点的数目,用来表示是否访问过一结点,访问前全置为0; 2接收用户要求开始访问的顶点,通过函数Adjfound(Graph G,VertexType c)找到改点在图的结点中的下标; 3若该下标对应的标志数组的值为0,访问该下标的firstArcNode结点,同时把该结点的在访问标志数组中的值设置为1;若该下标对应的标志数组的值为1,则进行第5步; 4继续进行操作2; 5在标志数组中查找仍为0的项,得到下标值再进行第1步操作;如果都访问过则遍历结束。 6退出程序。
评论星级较低,若资源使用遇到问题可联系上传者,3个工作日内问题未解决可申请退款~