#include<bits/stdc++.h>
const int inf=0x3f3f3f3f;
using namespace std;
struct node
{
int v;
int c;
int next;
}e[20005];
int vis[505],dis[505];
int h[20005];
int m,n;
int top;
void read(int u,int v,int c)
{
e[top].v=v;
e[top].c=c;
e[top].next=h[u];
h[u]=top++;
e[top].v=u;
e[top].c=c;
e[top].next=h[v];
h[v]=top++;
return;
}
int spfa()
{
queue<int>q;
for(int i=1;i<=m;i++)
{
vis[i]=0;
dis[i]=inf;
}
dis[1]=0;
vis[1]=1;
q.push(1);
int now;
while(!q.empty())
{
now=q.front();
q.pop();
vis[now]=0;
for(int i=h[now];i!=-1;i=e[i].next)
{
int v=e[i].v;
if(dis[v]>dis[now]+e[i].c)
{
dis[v]=dis[now]+e[i].c;
if(!vis[v])
{
vis[v]=1;
q.push(v);
}
}
}
}
return dis[m];
}
int main()
{
while(~scanf("%d%d",&m,&n))
{
if(m==0&&n==0)
break;
top=1;
memset(h,-1,sizeof(h));
for(int i=0;i<n;i++)
{
int a,b,c;
scanf("%d%d%d",&a,&b,&c);
read(a,b,c);
}
int s=spfa();
printf("%d\n",s);
}
return 0;
}