#include <stdio.h> #include <stdlib.h> #include <string.h> #include "ALGraph.h" int visited[MAXVEX]; /*设访问标志数组为全局变量*/ void DFSTraverse(ALGraph g)/*深度优先遍历以邻接表存储的图g*/ { int i; for(i=0;i<g.vexnum;i++) /*访问标志数组初始化*/ visited[i]=0; for(i=0;i<g.vexnum;i++) if(!visited[i]) DFS(g,i); /*对尚未访问的顶点调用DFS函数*/ } void DFS(ALGraph g, int i)/*从未被访问的顶点Vi出发深度优先遍历图g*/ { // 请在这里补充代码,完成本关任务 /********** Begin *********/ /********** End **********/ }
时间: 2023-07-23 16:00:46 浏览: 152
void DFS(ALGraph g, int i)/*从未被访问的顶点Vi出发深度优先遍历图g*/
{
visited[i] = 1; /*将顶点i标记为已访问*/
printf("%c ", g.vertices[i].data); /*输出顶点i的值*/
EdgeNode *p = g.vertices[i].firstedge; /*获取顶点i的第一个邻接边*/
while (p) {
if (!visited[p->adjvex]) { /*如果该邻接顶点未被访问*/
DFS(g, p->adjvex); /*递归调用DFS函数*/
}
p = p->next; /*继续遍历下一个邻接边*/
}
}
相关问题
#include <stdio.h> #include <stdlib.h> #include <string.h> #include "ALGraph.h" int visited[MAXVEX]; /设访问标志数组为全局变量/ void DFSTraverse(ALGraph g)/深度优先遍历以邻接表存储的图g/ { int i; for(i=0;i<g.vexnum;i++) /访问标志数组初始化/ visited[i]=0; for(i=0;i<g.vexnum;i++) if(!visited[i]) DFS(g,i); /对尚未访问的顶点调用DFS函数/ } void DFS(ALGraph g, int i)/从未被访问的顶点Vi出发深度优先遍历图g/ { // 请在这里补充代码,完成本关任务 /********** Begin *********/ /********** End **********/ }在begin和end之间完成代码
请在 `DFS` 函数的 `// 请在这里补充代码,完成本关任务` 的部分添加以下代码:
```c
visited[i] = 1; // 将当前顶点标记为已访问
printf("%c ", g.vertices[i].data); // 输出当前访问的顶点值
// 遍历当前顶点的邻接表,递归访问未访问的邻接顶点
ArcNode* p = g.vertices[i].firstarc;
while (p) {
if (!visited[p->adjvex]) {
DFS(g, p->adjvex);
}
p = p->nextarc;
}
```
这段代码实现了深度优先遍历,首先将当前顶点标记为已访问,然后输出当前访问的顶点值。接着遍历当前顶点的邻接表,如果某个邻接顶点未被访问过,则递归调用 DFS 函数进行访问。这样就可以完成深度优先遍历图的操作。
实现基于邻接表表示的深度优先遍历。 函数接口定义: void DFS(ALGraph G, int v); 其中 G 是基于邻接表存储表示的无向图,v表示遍历起点。 裁判测试程序样例: #include <stdio.h> #include <stdlib.h> #define MVNum 10 int visited[MVNum]; typedef struct ArcNode{ int adjvex; struct ArcNode *nextarc; int info; }ArcNode; typedef struct VNode{ char data; ArcNode *firstarc; }VNode, AdjList[MVNum]; typedef struct{ AdjList vertices; int vexnum, arcnum; }ALGraph; int CreateUDG(ALGraph &G);//实现细节隐藏 void DFS(ALGraph G, int v); void DFSTraverse(ALGraph G){ int v; for(v = 0; v < G.vexnum; ++v) visited[v] = 0; for(v = 0; v < G.vexnum; ++v) if(!visited[v]) DFS(G, v); } int main(){ ALGraph G; CreateUDG(G); DFSTraverse(G); return 0; } /* 请在这里填写答案 */ 输入样例: 输入第1行为结点数vexnum和边数arcnum。第2行为结点的值,依次输入arcnum行,每行输入两个结点的值表示该两个结点互为邻接点。 8 8 ABCDEFGH A B A C B D B E C F C G D H E H 输出样例: 遍历序列。 A C G F B E H D
void DFS(ALGraph G, int v)
{
visited[v] = 1; // 标记当前节点已经访问过
printf("%c ", G.vertices[v].data); // 输出当前节点的值
ArcNode *p = G.vertices[v].firstarc; // 指向当前节点的第一条边
while (p != NULL) // 遍历与当前节点相邻的节点
{
int w = p->adjvex; // 获取当前节点的相邻节点
if (!visited[w]) // 如果该相邻节点未被访问过
{
DFS(G, w); // 递归访问该相邻节点
}
p = p->nextarc; // 指向当前节点的下一条边
}
}
注意,在调用 DFS 函数之前需要先将 visited 数组初始化为 0,表示所有节点都未被访问过。同时,如果图不是连通的,需要在 DFSTraverse 函数中使用循环遍历每个节点,以确保对所有节点都进行了遍历。
阅读全文