-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathTreeGraphBFS.cpp
59 lines (58 loc) · 1.28 KB
/
TreeGraphBFS.cpp
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
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
#include <stdio.h>
#include <conio.h>
#include <stdlib.h>
#define MAX 50
#define TRUE 1
#define FALSE 0
int CBT[MAX][2], n, A[MAX][MAX], chuaxet[MAX], sc, QUEUE[MAX];
void Init(void){
int i, j;FILE *fp;
fp= fopen("BAOTRUM1.IN", "r");
if(fp==NULL){
printf("\n Khong co file input");
getch(); return;
}
fscanf(fp,"%d",&n);
printf("\n So dinh do thi:%d", n);
printf("\n Ma tran ke:");
for(i=1; i<=n; i++){
printf("\n");
for(j=1; j<=n; j++){
fscanf(fp, "%d", &A[i][j]);
printf("%3d", A[i][j]);
}
}
fclose(fp);
for (i=1; i<=n;i++)
chuaxet[i]=TRUE;
}
void TREE_BFS(int u){
int dauQ, cuoiQ, v, p;
dauQ=1; cuoiQ=1; QUEUE[dauQ]=u;chuaxet[u]=FALSE;
while(dauQ<=cuoiQ){
v= QUEUE[dauQ]; dauQ=dauQ+1;
for(p=1; p<=n; p++){
if(chuaxet[p] && A[v][p]){
chuaxet[p]=FALSE; sc++;
CBT[sc][1]=v; CBT[sc][2]=p;
cuoiQ=cuoiQ+1;
QUEUE[cuoiQ]=p;
if(sc==n-1) return;
}
}
}
}
void Result(void){
int i, j;
for(i=1; i<=sc; i++){
printf("\n Canh %d:", i);
for(j=1; j<=2; j++)
printf("%3d", CBT[i][j]);
}
}
int main(void){
int i; Init(); sc=0; i=1; /* xây dựng cây bao trùm tại đỉnh 1*/
TREE_BFS(i);
if (sc<n-1) printf("\n Đồ thị không liên thông");
else Result();
}