有两个权值,距离相等的时候判断一下花费
3 2 1 2 5 6 2 3 4 5 1 3 0 0
9 11
#include <iostream> #include <cstdio> #include <cstring> #include <algorithm> using namespace std; const int maxn=1100; const int INF=0x3f3f3f3f; int c[maxn][maxn],w[maxn][maxn]; int n,m; int origional,vis[maxn],dist[maxn],cost[maxn]; void dijkstra() { memset(vis,0,sizeof(vis)); memset(dist,63,sizeof(dist)); memset(cost,63,sizeof(cost)); cost[origional]=dist[origional]=0; for(int l=0;l<n;l++) { int mark=-1,mindist=INF; for(int i=1;i<=n;i++) { if(vis[i]) continue; if(mindist>dist[i]) { mark=i; mindist=dist[i]; } } vis[mark]=1; for(int i=1;i<=n;i++) { if(vis[i]) continue; if(dist[i]>dist[mark]+w[mark][i]) { dist[i]=dist[mark]+w[mark][i]; cost[i]=cost[mark]+c[mark][i]; } else if(dist[i]==dist[mark]+w[mark][i]&&cost[i]>cost[mark]+c[mark][i]) { cost[i]=cost[mark]+c[mark][i]; } } } } int main() { while(scanf("%d%d",&n,&m)!=EOF) { if(n==0&&m==0) break; memset(c,63,sizeof(c)); memset(w,63,sizeof(w)); int a,b,d,p; for(int i=0;i<m;i++) { scanf("%d%d%d%d",&a,&b,&d,&p); if(d<w[a][b]) { c[a][b]=c[b][a]=p; w[a][b]=w[b][a]=d; } } int s,t; scanf("%d%d",&s,&t); origional=s; dijkstra(); printf("%d %d\n",dist[t],cost[t]); } return 0; }