Pagini recente » Cod sursa (job #1014280) | Cod sursa (job #3277699) | Cod sursa (job #2143486) | Cod sursa (job #2104241) | Cod sursa (job #973922)
Cod sursa(job #973922)
#include <fstream>
using namespace std;
ifstream f("bfs.in");
ofstream g("bfs.out");
int m,n,s,x,y,i,d[10000],a[10000][10000],c[10000],p,u,nc;
bool v[100000];
int main()
{
f>>n>>m>>s;
for(i=1;i<=m;i++)
f>>x>>y,a[x][y]=1;
for (i=1;i<=n;i++) v[i]=false;
c[0]=s;
v[s]=true;
while(p<=u)
{
nc=c[p++];
for (i=1;i<=n;i++)
if (a[nc][i]==1 && v[i]==false )
d[i]=d[nc]+1,c[++u]=i,v[i]=true;
}
for (i=1;i<=n;i++) if (v[i]==true) g<<d[i]<<' ';
else g<<"-1"<<' ';
return 0;
}