隣接行列メモリマップ(20分)の6.1練習深さ優先トラバーサル

試験隣接行列ストレージ図の深さ優先トラバーサルを実装します。

関数インタフェースの定義:

void DFS( MGraph Graph, Vertex V, void (*Visit)(Vertex) ); 
 

前記MGraph図の隣接行列格納され、次のように定義されます。

typedef struct GNode *PtrToGNode; struct GNode{ int Nv; /* 顶点数 */ int Ne; /* 边数 */ WeightType G[MaxVertexNum][MaxVertexNum]; /* 邻接矩阵 */ }; typedef PtrToGNode MGraph; /* 以邻接矩阵存储的图类型 */ 
 

機能DFS最初べきV頂点の深さ優先トラバーサル図再帰的に起動は、Graph関数が定義されたときに審判を横断しVisit、各頂点にアクセスします。番号の昇順で必要とされる場合は、アクセスポイントの隣接関係、。トピック保証はV合法的な数字の頂点です。

審判のテストプログラムの例:

#include <stdio.h>

typedef enum {false, true} bool; #define MaxVertexNum 10 /* 最大顶点数设为10 */ #define INFINITY 65535 /* ∞设为双字节无符号整数的最大值65535*/ typedef int Vertex; /* 用顶点下标表示顶点,为整型 */ typedef int WeightType; /* 边的权值设为整型 */ typedef struct GNode *PtrToGNode; struct GNode{ int Nv; /* 顶点数 */ int Ne; /* 边数 */ WeightType G[MaxVertexNum][MaxVertexNum]; /* 邻接矩阵 */ }; typedef PtrToGNode MGraph; /* 以邻接矩阵存储的图类型 */ bool Visited[MaxVertexNum]; /* 顶点的访问标记 */ MGraph CreateGraph(); /* 创建图并且将Visited初始化为false;裁判实现,细节不表 */ void Visit( Vertex V ) { printf(" %d", V); } void DFS( MGraph Graph, Vertex V, void (*Visit)(Vertex) ); int main() { MGraph G; Vertex V; G = CreateGraph(); scanf("%d", &V); printf("DFS from %d:", V); DFS(G, V, Visit); return 0; } /* 你的代码将被嵌在这里 */ 
 

サンプル入力:図に示すように。

5
 

出力例:

DFS from 5: 5 1 3 0 2 4 6

コード:
ボイド DFS(MGraphグラフ、頂点V、ボイド(* 訪問)(頂点)){ 
    訪問[V] = 
    訪問(V); 
    以下のためにINT iが= 0 ; I <グラフ- >ネバダ州; I ++ ){
         場合([I] ||グラフを訪問- > G [V] [I] == INFINITY)を続けます
        DFS(グラフ、I、訪問)。
    } 
}

 

おすすめ

転載: www.cnblogs.com/8023spz/p/12283934.html