PTA(图)1-5 实现基于邻接表表示的深度优先遍历

1-5 实现基于邻接表表示的深度优先遍历

分数 4

作者 王东

单位 贵州师范学院

实现基于邻接表表示的深度优先遍历。

函数接口定义:

1
void DFS(ALGraph G, int v);

其中 G 是基于邻接表存储表示的无向图,v表示遍历起点。

裁判测试程序样例:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
#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行,每行输入两个结点的值表示该两个结点互为邻接点。

1
2
3
4
5
6
7
8
9
10
8 8
ABCDEFGH
A B
A C
B D
B E
C F
C G
D H
E H

输出样例:

遍历序列。

1
A C G F B E H D 

QQ截图20191125133700.png


我的正确答案

  • 我之前的错误修正
    • 修正递归参数:注意将 DFS(G, p->nextarc->adjvex) 改为 DFS(G, p->adjvex),递归访问当前邻接边对应的顶点(而非下一条边的顶点),避免空指针
    • 添加指针移动:在循环内添加 p = p->nextarc,确保遍历完当前顶点的所有邻接边,不会陷入无限循环。
1
2
3
4
5
6
7
8
9
10
11
12
13
#include <iostream>
using namespace std;
void DFS(ALGraph G, int v) {
visited[v] = 1;
cout << G.vertices[v].data << " ";
ArcNode *p = G.vertices[v].firstarc;
while (p != NULL) {
if (!visited[p->adjvex]) {
DFS(G, p->adjvex);
}
p = p->nextarc;
}
}