解题思路:

#include<iostream>
using namespace std;
#define MAX_VERTEX_NUM 50 // 定义最大结点数;
#define MAXQSIZE 100 // 最大队长;
int graph[MAX_VERTEX_NUM][MAX_VERTEX_NUM]; // 构造空邻接矩阵;
int visited[MAX_VERTEX_NUM]; // 构造访问数组;
int u;

typedef struct // 队列的顺序存储结构;
{
	int* base; // 存储空间的基地址;
	int front; // 头指针;
	int rear; // 尾指针;
}SqQueue;

SqQueue Q;

int InitQueue(SqQueue& Q)
{
	Q.base = new int[MAXQSIZE]; // 为队列分配一个最大容量为MAXQSIZE的数组空间;
	if (!Q.base) exit(0); // 存储分配失败;
	else
	{
		Q.front = Q.rear = 0; // 头指针和尾指针指向队头,置空;
		return 1;
	}
}
int EnQueue(SqQueue& Q, int e) //入队(队尾入队)
{
	if ((Q.rear + 1) % MAXQSIZE == Q.front) // 判断队列是否已满,如果尾指针+1模MAX==头指针,说明队满;
		return 0;
	else
	{
		Q.base[Q.rear] = e; // 入队;
		Q.rear = (Q.rear + 1) % MAXQSIZE; // 队尾指针+1(若溢出,返回队头);
		return 1;
	}
}
int DeQueue(SqQueue& Q, int& e) // 出队(队头出队)
{
	if (Q.front == Q.rear)// 如果队空,不用出队;
		return 0;
	else
	{
		e = Q.base[Q.front];
		Q.front = (Q.front + 1) % MAXQSIZE;
		return e;
	}
}
int QueueEmpty(SqQueue Q)
{
	if (Q.front == Q.rear)
		return 1;
	else
		return 0;
}


int FirstAdjVex(int v, int n) // 返回u的第一个邻接点;
{
	for (int i = 0; i < n; i++)
	{
		if (graph[v][i] == 1 && !visited[i])
		{
			return i;
		}
	}
	return -1; // 如果找不到下一个邻接点,返回-1
}
int NextAdjVex(int v, int w, int n) // 返回u相对w的下一个邻接点;
{
	for (int i = w + 1; i < n; i++)
	{
		if (graph[v][i] == 1 && !visited[i])
		{
			return i;
		}
	}
	return -1; 
}


void BFS(int v,int n)
{
	cout << v << " "; // 输出访问的结点;
	visited[v] = 1; // 对于访问过的结点,令访问数组值为1;
	InitQueue(Q); // 初始化辅助队列Q,并置空;
	EnQueue(Q, v); // 访问过的结点v入队;
	while (!QueueEmpty(Q)) // 如果队列非空;
	{
		DeQueue(Q, u); // 队头元素出队并置为u;
		for (int w = FirstAdjVex(u,n); w >= 0; w = NextAdjVex(u, w,n)) // 依次检查u的所有邻接点w,FirstAdjVex()表示u的第一个邻接点,NextAdjVex()表示u相对于w的下一个邻接点,w>=0表示存在邻接点(V0,V1,V2,V3);
		{
			if (!visited[w])
			{
				cout << w<<" ";
				visited[w] = 1;
				EnQueue(Q, w);
			}
		}
	}
}

int main()
{
	int n;
	cin >> n; // 输入结点总数;
	for (int i = 0; i < n; i++)
	{
		for (int j = 0; j < n; j++)
		{
			cin >> graph[i][j]; // 构造邻接矩阵;
		}
	}
	for (int i = 0; i < n; i++)
		visited[i] = 0; // 初始化访问数组(令其所有值为0);

	BFS(0, n);

	return 0;
}


注意事项:

参考代码:

点赞(0)
 

0.0分

0 人评分

C语言网提供由在职研发工程师或ACM蓝桥杯竞赛优秀选手录制的视频教程,并配有习题和答疑,点击了解:

一点编程也不会写的:零基础C语言学练课程

解决困扰你多年的C语言疑难杂症特性的C语言进阶课程

从零到写出一个爬虫的Python编程课程

只会语法写不出代码?手把手带你写100个编程真题的编程百练课程

信息学奥赛或C++选手的 必学C++课程

蓝桥杯ACM、信息学奥赛的必学课程:算法竞赛课入门课程

手把手讲解近五年真题的蓝桥杯辅导课程

评论列表 共有 0 条评论

暂无评论