#include <iostream> #include <cstdio> #include <queue> #include <cstring> #define INF 65535 using namespace std; typedef pair<int,int> Node; int n,m; int G[107][107]; bool operator < (Node a,Node b) { return a.first > b.first; } int Dijkstra() { int v,min; int d[107]; int vis[107]; priority_queue<Node> q; memset(vis,0,sizeof(vis)); for(int i = 1;i <= n;i++) d[i] = INF; d[1] = 0; q.push(make_pair(d[1],1)); while(!q.empty()) { Node t = q.top(); q.pop(); if(vis[t.second]) continue; vis[t.second] = 1; for(int i = 1;i <= n;i++) if(!vis[i] && d[i] > t.first+G[t.second][i]) { d[i] = t.first+G[t.second][i]; q.push(make_pair(d[i],i)); } } return d[n]; } int main() { int x,y,w; while(~scanf("%d%d",&n,&m)) { if(!n && !m) break; for(int i = 1;i <= n;i++) for(int j = 1;j <= n;j++) G[i][j] = i==j?0:INF; for(int i = 1;i <= m;i++) { scanf("%d%d%d",&x,&y,&w); if(w < G[x][y]) G[x][y] = G[y][x] = w; } printf("%d\n",Dijkstra()); } return 0; }
原文:http://www.cnblogs.com/immortal-worm/p/4991247.html