Pagini recente » Cod sursa (job #1590893) | Cod sursa (job #3197641) | Cod sursa (job #2416003) | Cod sursa (job #1863372) | Cod sursa (job #2288217)
#include<stdio.h>
const int N=50001;
struct G {
int a,b,c;
}g[5*N];
int m,i,o,n,d[N];
int main() {
freopen("dijkstra.in","r",stdin),freopen("dijkstra.out","w",stdout),scanf("%d%d",&n,&m);
for(i=1;i<=m;i++)
scanf("%d%d%d",&g[i].a,&g[i].b,&g[i].c);
for(i=2;i<=n;i++)
d[i]=N;
while(!o) {
for(o=i=1;i<=m;i++)
if(d[g[i].b]>d[g[i].a]+g[i].c)
o=0,d[g[i].b]=d[g[i].a]+g[i].c;
}
for(i=2;i<=n;i++)
printf("%d ",d[i]==N?0:d[i]);
}