Pagini recente » Cod sursa (job #2883617) | Cod sursa (job #2417110) | Cod sursa (job #941781) | Cod sursa (job #3040602) | Cod sursa (job #294002)
Cod sursa(job #294002)
#include<fstream>
#define INF 1<<30
using namespace std;
int d[50010],a[250010],b[250010],c[250010],i,ok,n,m;
int main()
{
ifstream f("dijkstra.in");
ofstream g("dijkstra.out");
f>>n>>m;
for(i=2;i<=n;i++) d[i]=INF;
for(i=1;i<=m;i++)
{ f>>a[i]>>b[i]>>c[i];
if(a[i]==1) d[b[i]]=c[i];
}
while(!ok)
{ ok=1;
for(i=1;i<=m;i++)
if( d[b[i]] > d[a[i]]+c[i] )
d[b[i]]=d[a[i]]+c[i], ok=0;
}
for(i=2;i<=n;i++)
if(d[i]==INF) g<<"0"<<" ";
else g<<d[i]<<" ";
f.close();
g.close();
return 0;
}