Pagini recente » Cod sursa (job #1702994) | Cod sursa (job #588344) | Statistici Nedelcu Ana-Florentina (Lorien) | Cod sursa (job #739890) | Cod sursa (job #345879)
Cod sursa(job #345879)
#include <stdio.h>
#include <list>
#include <queue>
using namespace std;
int n, m, s, drum[10010];
list<int>a[10010];
void BF();
int main() {
int x, y, i;
FILE *in = fopen("bf.in", "r"), *out= fopen("bf.out", "w");
fscanf(in, "%d%d%d", &n, &m, &s);
for(i=1; i<=m; i++) {
fscanf(in, "%d%d", &x, &y);
a[x].push_back(y);
}
for(i=1; i<=n; i++) {
drum[i]=-1;
}
BF();
for(i=1; i<=n; i++) {
fprintf(out, "%d ", drum[i]);
}
return 0;
}
void BF() {
int p;
queue<int>c;
c.push(s); drum[s]=0;
while(!c.empty()) {
p=c.front();
for(list<int>::iterator it=a[p].begin(); it!=a[p].end(); it++) {
if(drum[*it]==-1) {
drum[*it]=drum[p]+1;
c.push(*it);
}
}
c.pop();
}
}