Pagini recente » Cod sursa (job #3142969) | Cod sursa (job #2259293) | Cod sursa (job #970866) | Cod sursa (job #887618) | Cod sursa (job #3350200)
#include <bits/stdc++.h>
using namespace std;
ifstream fin ("dijkstra.in") ;
ofstream fout ("dijkstra.out") ;
const int INF = 1e9 + 5 ;
vector < pair < int , int > > g[50005] ;
int d[50005] ;
void dijkstra ( int nod )
{
for ( auto it : g[nod] )
{
if ( d[nod] + it.second < d[it.first] )
{
d[it.first] = d[nod] + it.second ;
dijkstra ( it.first ) ;
}
}
}
void solve ()
{
int n , m ;
fin >> n >> m ;
for ( int i = 1 ; i <= m ; i ++ )
{
int x , y , c ;
fin >> x >> y >> c ;
g[x].push_back({y,c}) ;
g[y].push_back({x,c}) ;
}
for ( int i = 2 ; i <= n ; i ++ )
d[i] = INF ;
dijkstra ( 1 ) ;
for ( int i = 2 ; i <= n ; i ++ )
if ( d[i] != INF )
fout << d[i] << " " ;
else
fout << 0 << " " ;
}
int main()
{
std :: ios_base :: sync_with_stdio ( false ) ;
fin.tie(0) ;
fout.tie(0) ;
solve() ;
return 0;
}