Pagini recente » Cod sursa (job #3260843) | Cod sursa (job #2899171) | Cod sursa (job #1608688) | Cod sursa (job #155034) | Cod sursa (job #2487807)
#include <iostream>
#include <fstream>
#include <vector>
#define NMAX 100000
using namespace std;
ifstream f("bfs.in");
ofstream g("bfs.out");
vector <int> v[NMAX],viz,res;
int n,m,s;
void bfs(int k,int nr)
{
vector <int> t;
for(auto x:v[k])
if(!viz[x])
{
t.push_back(x);
viz[x]=1;
res[x]=nr;
}
++nr;
for(auto x:t)
bfs(x,nr);
}
int main()
{
f>>n>>m>>s;
for(int i=0;i<n;++i)
{
viz.push_back(0);
res.push_back(-1);
}
for(int i=0;i<m;++i)
{
int x,y;
f>>x>>y;
v[x-1].push_back(y-1);
}
--s;
res[s]=0;
viz[s]=1;
bfs(s,1);
for(auto x:res)
g<<x<<' ';
return 0;
}