#define _CRT_SECURE_NO_WARNINGS 1
/*设计一个有向图和一个无向图,建立图的邻接矩阵或邻接表的存储结构
完成有向图和无向图的DFS(深度优先遍历)
BFS(广度优先遍历)的操作。(有向图采用邻接矩阵存储,无向图采用邻接表存储)*/
#include<stdio.h>
#include<stdlib.h>
#define MAXVEX 100
#define INF 0
typedef struct MGraph
{
char data;
int Vertex[MAXVEX];
int Arc[MAXVEX][MAXVEX];
int vexnum, arcnum;
}MGraph;
//有向图的邻接矩阵 MG
void CreatMGraph(MGraph& G)
{
int i, j;
printf("建立有向图的邻接矩阵\n");
printf("请输入顶点数和边数:");
scanf("%d %d", &G.vexnum, &G.arcnum);
getchar();
printf("请输入顶点信息:");
for (i = 0; i < G.vexnum; i++)
{
scanf("%c", &G.Vertex[i]);
}
//初始化边表
for (i = 0; i < G.vexnum; i++)
{
for (j = 0; j < G.vexnum; j++)
{
G.Arc[i][j] = INF;
}
}
//建立邻接矩阵
for (int k = 0; k < G.arcnum; k++)
{
printf("请输入(Vi,Vj)的i,j的下标:");
scanf("%d %d", &i, &j);
G.Arc[i][j] = 1;
}
}
void PrintMGraph(MGraph G)
{
int i, j;
for (i = 0; i < G.vexnum; i++)
{
printf("%c:", G.Vertex[i]);
for (j = 0; j < G.vexnum; j++)
{
printf("%d ", G.Arc[i][j]);
}
printf("\n");
}
}
typedef struct ArcNode
{
int adjvex;
ArcNode* next;
}ArcNode;
typedef struct VNode
{
char data;
ArcNode* first;
}VNode,AdjList[MAXVEX];
typedef struct
{
AdjList vertices;
int vexnum, arcnum;
}ALGraph;
//无向图的邻接表 ALG
void CreatALGraph(ALGraph& G)
{
printf("建立无向图的邻接表\n");
int i, j;
printf("请输入顶点数和边数:");
scanf("%d %d", &G.vexnum, &G.arcnum);
getchar();
printf("请输入顶点信息:");
for (i = 0; i < G.vexnum; i++)
{
scanf("%c", &G.vertices[i].data);
G.vertices[i].first = NULL;
}
//建立邻接表
for (int k = 0; k < G.arcnum; k++)
{
printf("请输入(Vi,Vj)的i,j的下标:");
scanf("%d %d", &i, &j);
ArcNode* s = (ArcNode*)malloc(sizeof(ArcNode));
s->adjvex = j;
s->next = G.vertices[i].first;
G.vertices[i].first = s;
ArcNode* m = (ArcNode*)malloc(sizeof(ArcNode));
m->adjvex = i;
m->next = G.vertices[j].first;
G.vertices[j].first = m;
}
}
void PrintALGraph(ALGraph G)
{
ArcNode* p;
for (int i = 0; i < G.vexnum; i++)
{
printf("%c:", G.vertices[i].data);
for (p = G.vertices[i].first; p; p = p->next)
{
printf("%2c", G.vertices[p->adjvex].data);
}
printf("\n");
}
}
//全局变量,表示是否访问过
int Visited1[MAXVEX];
int Visited2[MAXVEX];
int Visited3[MAXVEX];
int Visited4[MAXVEX];
//有向图的邻接矩阵 MG 广度优先遍历
void BFS(MGraph& G, int i)
{
Visited1[MAXVEX] = { 0 };
//非递归,要用到队列
int front, rear;
int Q[MAXVEX];
front = rear = -1; // 初始化队列
printf("%c ", G.Vertex[i]); // 输出当前结点
Visited1[i] = 1; // 表示访问过了
Q[++rear] = i; // 入队
while (front != rear)
{
i = Q[++front];
for (int j = 0; j < G.vexnum; j++)
{
if (G.Arc[i][j] != INF && Visited1[j] == 0)
{
printf("%c ", G.Vertex[j]);
Visited1[j] = 1; // 已访问
Q[++rear] = j; // 入队
}
}
}
}
//无向图的邻接表 ALG 广度优先遍历
void BFS(ALGraph& G, int v)
{
Visited2[MAXVEX] = { 0 };
int front, rear;
int Q[MAXVEX];
front = rear = -1;
printf("%2c", G.vertices[v].data);
Visited2[v] = 1;
Q[++rear] = v;
while (front != rear)
{
v = Q[++front];
for (ArcNode* p = G.vertices[v].first; p; p = p->next)
{
if (Visited2[p->adjvex] == 0)
{
printf("%2c", G.vertices[p->adjvex].data);
Visited2[p->adjvex] = 1;
Q[++rear] = p->adjvex;
}
}
}
}
//有向图的邻接矩阵 MG 深度优先遍历递归
void DFS(MGraph& G, int i)
{
Visited3[MAXVEX] = { 0 };
if (i < 0 || i >= G.vexnum)
{
printf("i的位置出错!");
return;
}
printf("%2c", G.Vertex[i]);
Visited3[i] = 1;
for (int j = 0; j < G.vexnum; j++)
{
if (Visited3[j] == 0 && G.Arc[i][j] != INF)
{
DFS(G, j);
}
}
}
//无向图的邻接表 ALG 深度优先遍历递归
void DFS(ALGraph& G, int i)
{
Visited4[MAXVEX] = { 0 };
if (i < 0 || i >= G.vexnum)
{
printf("i的位置出错!");
return;
}
printf("%2c", G.vertices[i].data);
Visited4[i] = 1;
ArcNode* p = G.vertices[i].first;
while (p)
{
if (Visited4[p->adjvex] == 0)
{
DFS(G, p->adjvex);
}
p = p->next;
}
}
int main()
{
int i, j;
MGraph MG;
ALGraph ALG;
CreatMGraph(MG);
PrintMGraph(MG);
printf("-----------------------------------\n");
printf("有向图的邻接矩阵 MG 广度优先遍历\n");
printf("从A开始:");
BFS(MG, 0);
printf("\n");
printf("-----------------------------------\n");
printf("有向图的邻接矩阵 MG 深度优先遍历\n");
printf("从A开始:");
DFS(MG, 0);
printf("\n");
printf("-----------------------------------\n");
CreatALGraph(ALG);
PrintALGraph(ALG);
printf("-----------------------------------\n");
printf("无向图的邻接表 ALG 广度优先遍历\n");
printf("从A开始:");
BFS(ALG, 0);
printf("\n");
printf("-----------------------------------\n");
printf("无向图的邻接表 ALG 深度优先遍历\n");
printf("从A开始:");
DFS(ALG, 0);
printf("\n");
printf("-----------------------------------\n");
return 0;
}
测试数据:
/*
7 8
ABCDEFG
0 1
0 2
1 0
1 3
2 4
2 5
4 6
5 6
7 7
ABCDEFG
0 1
0 2
1 3
2 4
2 5
4 6
5 6
*/