1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72
| #include "stdafx.h" #include <iostream> using namespace std;
#define MAX 1000 #define MAXCOST 0x3f3f3f3f
int graph[MAX][MAX];
int prim(int graph[][MAX], int n) { int lowcost[MAX]; int mst[MAX]; int i, j, min, minid; int max = 0; for (i = 2; i <= n; i++) { lowcost[i] = graph[1][i]; mst[i] = 1; } mst[1] = 0; for (i = 2; i <= n; i++) { min = MAXCOST; minid = 0; for (j = 2; j <= n; j++) { if (lowcost[j] < min && lowcost[j] != 0) { min = lowcost[j]; minid = j; } } if (min > max) max = min; lowcost[minid] = 0; for (j = 2; j <= n; j++) { if (graph[minid][j] < lowcost[j] && lowcost[j] != 0) { lowcost[j] = graph[minid][j]; mst[j] = minid; } } } return max; }
int main() { int T; int s; int sum; memset(graph, MAXCOST, sizeof(graph)); scanf("%d", &T); while (T--) { scanf("%d", &s); for (int i = 1; i < s + 1; i++) for (int j = 1; j < s + 1; j++) { scanf("%d", &graph[i][j]); if (!graph[i][j]) graph[i][j] = MAXCOST; } sum = prim(graph, s); cout << sum << endl; }
system("pause"); }
|