#include<bits/stdc++.h>
using namespace std;
int a[3010][3010];// 存储
int d[3010],n,m;//最终
bool v[3010];//是否走过
void dijkstra()//
{
memset(d,0x3f,sizeof(d));//
memset(v,0,sizeof(v));//
d[1]=0;//
for(int i=1;i<n;i++)//
{
int x=0;//
for(int j=1;j<=n;j++)//
{
if(!v[j]&&(x==0||d[j]<d[x]))//找最小的,没走过的
{
x=j;//
}
}
v[x]=1;//
for(int y=1;y<=n;y++)//根据最小的更新能走到的
{
d[y]=min(d[y],d[x]+a[x][y]);//
}
}
}
int main()///Dijkstra
{
cin>>n>>m;
memset(a,0x3f,sizeof(a));
for(int i=1;i<=n;i++)
{
a[i][i]=0;
}
for(int i=1;i<=m;i++)
{
int x,y,z;
scanf("%d %d %d",&x,&y,&z);
a[x][y]=min(a[x][y],z);
}
dijkstra();
for(int i=1;i<=n;i++)
{
printf("%d ",d[i]);
}
return 0;
}