南将军统领着N个部队,这N个部队分别驻扎在N个不同的城市。
他在用这N个部队维护着M个城市的治安,这M个城市分别编号从1到M。
现在,小工军师告诉南将军,第K号城市发生了暴乱,南将军从各个部队都派遣了一个分队沿最近路去往暴乱城市平乱。
现在已知在任意两个城市之间的路行军所需的时间,你作为南将军麾下最厉害的程序员,请你编写一个程序来告诉南将军第一个分队到达叛乱城市所需的时间。
注意,两个城市之间可能不只一条路。
1 3 8 9 8 1 2 3 1 2 1 2 3 2 1 4 2 2 5 3 3 6 2 4 7 1 5 7 3 5 8 2 6 8 2
4
1 #include<stdio.h> 2 #include<string.h> 3 #define inf 0xfffff 4 5 int g[1002][1002]; 6 int lowcost[1000001],used[1000001]; 7 8 void dijskra(int n,int a) 9 { 10 int i,j,k,min; 11 memset(used,0,sizeof(used)); 12 memset(lowcost,0,sizeof(lowcost)); 13 for(i=1;i<=n;i++) 14 lowcost[i]=g[i][a]; 15 used[a]=1; 16 for(i=1;i<n;i++) 17 { 18 j=a; 19 min=inf; 20 for(k=1;k<=n;k++) 21 { 22 if(lowcost[k]<min&&!used[k]) 23 { 24 min=lowcost[k]; 25 j=k; 26 } 27 } 28 used[j]=1; 29 for(k=1;k<=n;k++) 30 { 31 if(lowcost[j]+g[k][j]<lowcost[k]&&!used[k]) 32 lowcost[k]=lowcost[j]+g[k][j], 33 g[k][a]=g[a][k]=lowcost[k]; 34 } 35 } 36 } 37 38 int main() 39 { 40 int n,m,p,q,i,j,t; 41 int army; 42 scanf("%d",&t); 43 while(t--) 44 { 45 scanf("%d%d%d%d",&n,&m,&p,&q); 46 for(i=1;i<=m+1;i++) 47 { 48 for(j=1;j<=m+1;j++) 49 { 50 g[i][j]=inf; 51 } 52 g[i][i]=0; 53 } 54 for(i=0;i<n;i++) 55 { 56 scanf("%d",&army); 57 g[army][m+1]=g[m+1][army]=0; 58 } 59 for(i=0;i<p;i++) 60 { 61 int a,b,t; 62 scanf("%d%d%d",&a,&b,&t); 63 g[a][b]=g[b][a]=t; 64 } 65 dijskra(m+1,m+1); 66 printf("%d\n",g[q][m+1]); 67 } 68 }
南洋理工 OJ 115 城市平乱 dijstra算法,布布扣,bubuko.com
原文:http://www.cnblogs.com/zeze/p/chenshioinglua.html