邻接表的创建和图的遍历
#include <stdio.h> #include <stdlib.h> #define TRUE 1 #define FALSE 0 #define OK 1 #define ERROR 0 #define OVERFLOW -2 #define MAX_NUM 20 typedef int Status; typedef int QElemType; typedef char VexType; /* * 邻接表存储结构 */ typedef struct EdgeNode { int adjvex; //顶点的位置 struct EdgeNode *next; //指向下一条边的指针 }EdgeNode, *EdgeLink; typedef struct VexNode { VexType data; //顶点数据 EdgeNode *firstEdge; //指向第一条依附该顶点的边的指针 }VexNode, AdjList[MAX_NUM]; typedef struct { AdjList adjList; int vexNum, edgeNum; //顶点数和边数 }ALGraph; /* * 队列存储结构(用于图的遍历) */ typedef struct QNode { QElemType data; //结点数据 struct QNode *next; //指向下一个结点 }QNode, *QueuePtr; typedef struct { QueuePtr front; //队头指针 QueuePtr rear; //队尾指针 }LinkQueue; /* * 初始化队列 */ Status InitQueue(LinkQueue *Q) { Q->front = Q->rear = (QueuePtr) malloc(sizeof(QNode)); if (!Q->front) { exit(OVERFLOW); } Q->front->next = NULL; return OK; } /* * 判断队列是否为空 */ Status IsEmpty(LinkQueue Q) { if (Q.front->next == NULL) { return TRUE; } else { return FALSE; } } /* * 入队 */ Status EnQueue(LinkQueue *Q, QElemType e) { QueuePtr p = (QueuePtr) malloc(sizeof(QNode)); if (!p) { exit(OVERFLOW); } p->data = e; p->next = NULL; Q->rear->next = p; Q->rear = p; return OK; } /* * 出队 */ Status DeQueue(LinkQueue *Q, QElemType *e) { QueuePtr p; if (Q->front == Q->rear) { return ERROR; } p = Q->front->next; *e = p->data; Q->front->next = p->next; if (Q->rear == p) { Q->rear = Q->front; } free(p); return OK; } /* * 创建图 */ Status CreateGraph(ALGraph *G) { int i, j, k; EdgeLink e; printf("请输入顶点数目和边数:\n"); scanf("%d", &G->vexNum); scanf("%d", &G->edgeNum); getchar(); printf("请输入各顶点的数据:\n"); for (i = 0; i < G->vexNum; i++) { scanf("%c",&G->adjList[i].data); if (G->adjList[i].data == '\n') { i--; continue; } G->adjList[i].firstEdge = NULL; } printf("请依次输入边(Vi,Vj)的顶点序号:\n"); for (k = 0; k < G->edgeNum; k++) { scanf("%d", &i); scanf("%d", &j); e = (EdgeLink) malloc(sizeof(EdgeNode)); e->adjvex = j; e->next = G->adjList[i].firstEdge; G->adjList[i].firstEdge = e; e = (EdgeLink) malloc(sizeof(EdgeNode)); e->adjvex = i; e->next = G->adjList[j].firstEdge; G->adjList[j].firstEdge = e; } return OK; } int visited[MAX_NUM]; //用于记录遍历状态 /* * 递归从第i个结点深度优先遍历图 */ void DFS(ALGraph G, int i) { EdgeLink p; visited[i] = TRUE; printf("%c ", G.adjList[i].data); p = G.adjList[i].firstEdge; while (p) { if (!visited[p->adjvex]) { DFS(G, p->adjvex); } p = p->next; } } /* * 深度优先遍历 */ Status DFSTraverse(ALGraph G) { int i; for (i = 0; i < MAX_NUM; i++) { visited[i] = FALSE; } for (i = 0; i < G.vexNum; i++) { if (!visited[i]) { DFS(G, i); } } return OK; } /* * 广度优先遍历 */ Status BFSTraverse(ALGraph G) { int i; EdgeLink p; LinkQueue Q; InitQueue(&Q); for (i = 0; i < MAX_NUM; i++) { visited[i] = FALSE; } for (i = 0; i < G.vexNum; i++) { if (!visited[i]) { visited[i] = TRUE; printf("%c ", G.adjList[i].data); EnQueue(&Q, i); while (!IsEmpty(Q)) { DeQueue(&Q, &i); p = G.adjList[i].firstEdge; while (p) { if (!visited[p->adjvex]) { visited[p->adjvex] = TRUE; printf("%c ", G.adjList[p->adjvex].data); EnQueue(&Q, p->adjvex); } p = p->next; } } } } return OK; } int main() { ALGraph G; CreateGraph(&G); printf("深度优先遍历:"); DFSTraverse(G); printf("\n广度优先遍历:"); BFSTraverse(G); printf("\n"); }