图的邻接表+深度优先遍历+广度优先遍历

  1 /**
  2     无向图的邻接表存储
  3     深度优先遍历递归
  4     广度优先遍历递归+非递归
  5 */
  6 #include <stdio.h>
  7 #include <string.h>
  8 #include <malloc.h>
  9 #define N 5
 10 #define MAX 50
 11 typedef struct A{
 12     int adjvex;
 13     struct A* nextArc;
 14 }Arc;
 15 typedef struct node{
 16     char data[N];
 17     Arc* firstArc;
 18 }Node;
 19 typedef struct graph{
 20     Node vex[MAX];
 21     int numv;
 22     int nume;
 23 }Graph;
 24 
 25 int getIndex(Graph G,char s[]){
 26     for(int i = 0; i < G.numv; i++){
 27         if(strcmp(G.vex[i].data,s) == 0)
 28             return i;
 29     }
 30     return -1;
 31 }
 32 
 33 void create(Graph& G){
 34     printf("输入顶点和弧的个数:\n");
 35     scanf("%d%d",&G.numv,&G.nume);
 36     printf("输入顶点信息:\n");
 37     for(int i = 0; i < G.numv; i++)
 38         scanf("%s",G.vex[i].data);
 39     ///初始化顶点数组
 40     for(int i = 0; i < G.numv; i++)
 41         G.vex[i].firstArc = NULL;
 42     printf("输入边的信息:\n");
 43     char s[N],e[N];
 44     int u,v;
 45     for(int i = 0; i < G.nume; i++){
 46         scanf("%s%s",s,e);
 47         u = getIndex(G,s);
 48         v = getIndex(G,e);
 49         Arc* p = (Arc*)malloc(sizeof(Arc));
 50         p->adjvex = v;
 51         p->nextArc = NULL;
 52         p->nextArc = G.vex[u].firstArc;
 53         G.vex[u].firstArc = p;
 54         Arc* t = (Arc*)malloc(sizeof(Arc));
 55         t->nextArc = NULL;
 56         t->adjvex = u;
 57         t->nextArc = G.vex[v].firstArc;
 58         G.vex[v].firstArc = t;
 59     }
 60 }
 61 
 62 void output(Graph G){
 63     Arc* p;
 64     for(int i = 0; i < G.numv; i++){
 65         p = G.vex[i].firstArc;
 66         printf("%4s",G.vex[i].data);
 67         while(p != NULL){
 68             printf("%4s",G.vex[p->adjvex].data);
 69             p = p->nextArc;
 70         }
 71         printf("\n");
 72     }
 73 }
 74 
 75 ///深度优先遍历 (递归)
 76 int visit[2*MAX];
 77 void dfs(Graph G,int s){
 78     Arc* p = G.vex[s].firstArc;
 79     if(!visit[s]){
 80         printf("%4s",G.vex[s].data);
 81         visit[s] = 1;
 82     }
 83     while(p != NULL){
 84         if(!visit[p->adjvex])
 85             dfs(G,p->adjvex);
 86         p = p->nextArc;
 87     }
 88 }
 89 
 90 ///广度优先遍历 (递归)
 91 ///缺点递归最大为G.numv次
 92 int q[2*MAX],f=0,r=0;
 93 int visit_q[MAX];
 94 void bfs(Graph G,int s){
 95     if(!visit_q[s]){
 96         printf("%4s",G.vex[s].data);
 97         visit_q[s] = 1;
 98         Arc* p = G.vex[s].firstArc;
 99         while(p != NULL){
100             if(!visit_q[p->adjvex])
101                 q[r++] = p->adjvex;
102             p = p->nextArc;
103         }
104     }
105     while(f < r){
106         bfs(G,q[f++]);
107     }
108 }
109 
110 ///广度优先遍历 (非递归)
111 int Q[2*MAX],F=0,R=0;
112 int visit_Q[MAX];
113 void bfs_1(Graph G,int s){
114     printf("%4s",G.vex[s].data);
115     visit_Q[s] = 1;
116     Arc* p = G.vex[s].firstArc;
117     while(p != NULL){
118         Q[R++] = p->adjvex;
119         p = p->nextArc;
120     }
121     while(F < R){
122         int node = Q[F++];
123         if(!visit_Q[node]){
124             printf("%4s",G.vex[node].data);
125             visit_Q[node] = 1;
126             p = G.vex[node].firstArc;
127             while(p != NULL){
128                 if(!visit_Q[p->adjvex])
129                     Q[R++] = p->adjvex;
130                 p = p->nextArc;
131             }
132         }
133     }
134 }
135 
136 int main(void){
137     Graph G;
138     create(G); printf("输出邻接矩阵:\n");
139     output(G);
140     printf("深度优先遍历(递归):\n");
141     dfs(G,0);
142     printf("\n广度优先遍历(递归):\n");
143     bfs(G,0);
144     printf("\n广度优先遍历(非递归):\n");
145     bfs_1(G,0);
146     return 0;
147 }

测试用例:

8 9
v1 v2 v3 v4 v5 v6 v7 v8
v1 v2
v1 v3
v2 v4
v2 v5
v3 v6
v3 v7
v4 v8
v5 v8
v7 v6
v1
图(b)

8 7
v1 v2 v3 v4 v5 v6 v7 v8
v1 v2
v1 v3
v2 v4
v3 v6
v4 v8
v6 v7
v8 v5
v1
图(a)

8 10
1 2 3 4 5 6 7 8
1 2
1 3
2 4
2 5
3 6
3 7
4 8
5 8
6 8
7 8
1
图(d)

6 7
A B C D E F
A B
A E
B F
B E
F C
F D
D C
图(c)

posted @ 2016-07-24 18:55  赤云封天  阅读(7779)  评论(0编辑  收藏  举报