C语言利用图的邻接矩阵的存储方式实现有向图和无向图的广度优先搜索(BFS)

#include 
#include 
#define Max_Vetex_Num 100
#define MAXSIZE 20
#define STACK_SIZE 30

typedef struct {
    int vexs[Max_Vetex_Num];
    int arcs[Max_Vetex_Num][Max_Vetex_Num];
    int vexnum,arcnum;
}Mgraph;
typedef struct Squeue{
	int data[MAXSIZE];//队列内元素的最大长度
	int front;//队头
	int rear;//队尾
}Squeue;

//初始化队列
void InitQueue(Squeue *Q)
{
	Q->front = Q->rear = 0;
}

//判断队列是否为空
int isQueueEmpty(Squeue *qu)
{
	if(qu->front == qu->rear)
	{
		return 1;
	}
	else
	{
		return 0;
	}
}

//元素入队操作
int EnQueue(Squeue *qu,int x)
{
	if((qu->rear + 1) % MAXSIZE == qu->front)
	{
		return 0;
	}
	qu->rear = (qu->rear + 1) % MAXSIZE;
	qu->data[qu->rear] = x;
	return 1;
}

//元素出队操作
int deQueue(Squeue *qu,int *x)
{
	//若队空则无法出队
	if(qu->front == qu->rear)
	{
		return 0;
	}
	qu->front = (qu->front + 1) % MAXSIZE;
	*x = qu->data[qu->front];
	return 1;
}
void BFSTraverse(Mgraph *G)
{
    int i,f,r;
    int v,w;
    int visited[G->vexnum];

    Squeue Q;
    InitQueue(&Q);

    for(i =0;ivexnum;i++)
    {
        visited[i]=0;
    }
    for(v =0;vvexnum;v++)
    {
        if(!visited[v])
        {
            visited[v]=1;
            printf("%d ",G->vexs[v]);
            EnQueue(&Q,v);
            while(!isQueueEmpty(&Q))
            {
                int u;
                deQueue(&Q,&u);
                for(i=0;ivexnum;i++)
                {
                    if(G->arcs[u][i]&&visited[i]==0)
                    {
                        visited[i]=1;
                        printf("%d ",G->vexs[i]);
                        EnQueue(&Q,i);
                    }/*if*/
                }
            }/*WHILE*/

        }/*IF*/

    }/*FOR*/
}

void CreateMGraph(Mgraph *G){
    int type;
    int i,j,k,w;
    int v1,v2;
    scanf("%d",&type);
    if(type==0)
    {
        scanf("%d,%d",&(G->vexnum),&(G->arcnum));
        //自动构造顶点信息为index
        for(i=0;ivexnum;i++)
        {
            G->vexs[i]=i;
        }
        //初始化邻接矩阵,全部为0
        for(i=0;ivexnum;i++){
            for(j=0;jvexnum;j++){
                G->arcs[i][j]=0;
            }
        }

        //输入每行一个边的偶对,如v1,v2
        for(k=0;karcnum;k++)
        {
            scanf("%d,%d",&v1,&v2);
            G->arcs[v1][v2]=1;
            G->arcs[v2][v1]=1;
        }
    }else{
        scanf("%d,%d",&(G->vexnum),&(G->arcnum));
        //自动构造顶点信息为index
        for(i=0;ivexnum;i++)
        {
            G->vexs[i]=i;
        }
        //初始化邻接矩阵,全部为0
        for(i=0;ivexnum;i++){
            for(j=0;jvexnum;j++){
                G->arcs[i][j]=0;
            }
        }

        for(k=0;karcnum;k++)
        {
            scanf("%d,%d",&v1,&v2);

            G->arcs[v1][v2]=1;

        }
    }
    //PrintVex(G);
}

void PrintVex(Mgraph *G)
{
    int i,j;
    for(i=0;ivexnum;i++){
        for(j=0;jvexnum;j++)
        {
            printf("%d ",G->arcs[i][j]);
        }
        printf("\n");
    }
}
int main()
{
    Mgraph G;
    CreateMGraph(&G);
    BFSTraverse(&G);
    getchar();
    return 0;
}

 

你可能感兴趣的:(C语言,数据结构与算法)