1 4 6 1 2 10 2 3 10 3 1 10 1 4 1 2 4 1 3 4 1 1 3 5 6
4
程序代码:
#include <stdio.h> #include <string.h> #include <stdlib.h> #define MAX 1<<28 int map[505][505]; int e,v; int prime() { bool flag[505]; int path[505],i,j,sum=0; for(i=1;i<=v;i++) { flag[i]=0; path[i]=map[1][i]; } flag[1]=1; for(i=1;i<v;i++) { int k,min=MAX; for(j=1;j<=v;j++) { if(!flag[j]&&path[j]<min) { min=path[j]; k=j; } } sum+=path[k]; flag[k]=1; for(j=1;j<=v;j++) { if(!flag[j]&&path[j]>map[k][j]) path[j]=map[k][j]; } } return sum; } int main() { int n; scanf("%d",&n); while(n--) { int a,b,c,i; scanf("%d%d",&v,&e); memset(map,9999,sizeof(map)); while(e--) { scanf("%d%d%d",&a,&b,&c); if(map[a][b]) map[a][b]=map[b][a]=c<map[a][b]?c:map[a][b]; } int min=9999999,k; for(i=0;i<v;i++) { scanf("%d",&k); if(min>k) min=k; } printf("%d\n",prime()+min); } system("pause"); return 0; }
原文地址:http://blog.csdn.net/zchlww/article/details/41016107