#include <bits/stdc++.h>
using namespace std;
int k,m,n;
struct lr
{
int data,step; // data为节点的序号 step为到达节点需要的步数
} t;
int mmp[1010][1010]; //建立邻接矩阵存储图
bool vit[1010]; //储存已遍历的结点
struct lr que[1010]; //数组模拟队列
void BFS(int n)
{
int in = 0, out = 0; //队列头尾
que[in++] = (lr){n,0}; //t->data = n , t->step = 0 传入数值
while(in>out) //队列不为空
{
//int now = que[out++];
t = que[out++];
if(t.data == 1)//当节点为1时证明可以到达1号关隘
{
cout<<t.step;//直接输出步数即可
return ;
}
for(int i=0; i<n; i++)
{
if(!vit[i]&&mmp[t.data][i])
{
que[in++] = {i,t.step+1}; //入队列
vit[i] = true;
}
}
}
cout << "NO"; }
int main() {
int u,v;
while(cin >> n >> m)
{
memset(mmp,0,sizeof(mmp));
memset(vit,false,sizeof(vit));
while(m--)
{
cin >> u >> v;
mmp[u][v] =1; //单向图
}
vit[n] = true;
BFS(n);
cout << endl;
}
return 0; }
数据结构实验之图论五:从起始点到目标点的最短步数(BFS)
最新推荐文章于 2022-01-22 11:36:12 发布