Pagini recente » Cod sursa (job #1478285) | Cod sursa (job #2812771) | Cod sursa (job #97167) | Cod sursa (job #1048137) | Cod sursa (job #1049570)
#include <fstream>
#include <vector>
using namespace std;
ifstream fin("bfs.in");
ofstream fout("bfs.out");
int main()
{
vector<int> v[100001];
int n,m,s,i,j,*a,*u;
fin>>n>>m>>s;
a=new int[n+1];
u=new int[n];
for(i=1;i<=n;++i)
a[i]=-1;
while(m)
{
fin>>i>>j;
v[i].push_back(j);
m--;
}
for(j=0,a[s]=0,u[0]=s;j<=m;++j)
for(i=0;i<v[u[j]].size();++i)
if(a[v[u[j]][i]]==-1)
{
a[v[u[j]][i]]=a[u[j]]+1;
u[++m]=v[u[j]][i];
}
for(i=1;i<=n;++i)
fout<<a[i]<<" ";
}