2 1 1 2 2 1 2 1
1 1
代码:
#include <stdio.h>
#include <string.h>
#include <stdlib.h>
#include <vector>
#include <algorithm>
#include <queue>
using namespace std;
vector<int>q[100001];
//基于vector二维数组的BFS模拟遍历
void BFS(int n)
{
bool vis[100001];
memset(vis, false, sizeof(vis));
queue<int>p;
p.push(n);
vis[n]=true;
int dd;
vector<int>::iterator it;
int flag=0;
int cnt[100001];
memset(cnt, 0, sizeof(cnt));
while(!p.empty())
{
dd=p.front();
p.pop();
for(it=q[dd].begin(); it!=q[dd].end(); it++ )
{
if(vis[*it]==false)
{
cnt[*it]=cnt[dd]+1;
p.push(*it);
vis[*it]=true;
if(*it==1)
{
flag=1; break;
}
}
}
if(flag==1)
break;
}
if(flag==0 )
printf("NO\n");
else
printf("%d\n", cnt[1] );
}
int main()
{
int n, m;
int u, v;
int i, j;
while(scanf("%d %d", &n, &m)!=EOF)
{
for(i=0; i<=100000; i++)
{
q[i].clear();
}
for(i=0; i<m; i++)
{
scanf("%d %d", &u, &v );
q[u].push_back(v);
q[v].push_back(u);
}
BFS(n);
}
return 0;
}
/**************************************
Problem id : SDUT OJ 2830
Result : Accepted
Take Memory : 8312K
Take Time : 460MS
Submit Time : 2015-01-18 09:39:14
**************************************/
SDUT OJ 图练习-BFS-从起点到目标点的最短步数 (vector二维数组模拟邻接表+bfs , *【模板】 )
原文:http://www.cnblogs.com/yspworld/p/4231632.html