Pagini recente » Cod sursa (job #3224235) | Cod sursa (job #2261528) | Cod sursa (job #2922031) | Cod sursa (job #256321) | Cod sursa (job #408439)
Cod sursa(job #408439)
#include<iostream.h>
#include<fstream.h>
#define INF 32000
int n,i,j,d[100],e1,e2,c,a[100][100],v[100],sol[100],u;
int main()
{
freopen("dijkstra.in","r",stdin);
freopen("dijkstra.out","w",stdout);
cin>>n;
for(i=1;i<=n;i++)
d[i]=INF;
while(!cin.eof())
{
cin>>e1>>e2>>c;
a[e1][e2]=c;
}
for(i=1;i<=n;i++)
{
if(i!=1) d[i]=INF;
else d[1]=0;
}
sol[1]=1;
u=1;
for(j=1;j<=n;j++)
for(i=1;i<=n;i++)
if(a[sol[j]][i])
{
if(j!=1) if(a[sol[j]][i]+d[sol[j]]<d[i]) d[i]=a[sol[j]][i]+d[sol[j]];
if(j==1)if(a[sol[j]][i]<d[i]) d[i]=a[sol[j]][i];
u++;
sol[u]=i;
}
for(i=2;i<=n;i++) cout<<d[i]<<" ";
}