题意简洁,最小生成树问题。通过Prim算法求解,数据的处理有点困难。
CODE:
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
using namespace std;
const int SIZE = 110;
const int INF = 0x0fffffff;
int w[SIZE][SIZE];
int v[SIZE], d[SIZE];
int n;
int Prim(int src)
{
int i, j;
int tot = 0;
memset(v, 0, sizeof(v));
for(i = 1; i <= n ; i++) d[i] = (i == src)? 0:INF;
for(i = 1; i <= n; i++) //一次循环找出一条边。第一次不算。
{
int x, m = INF;
for(int y = 1; y <= n; y++) if(!v[y] && m >= d[y]) m = d[x=y];
v[x] = 1;
tot += m;
for(int y = 1; y <= n; y++) if(!v[y]) d[y] <?= w[x][y];
}
return tot;
}
void init()
{
int i, j;
for(i = 1; i <= SIZE; i++)
{
for(j = 1; j <= SIZE; j++)
{
w[i][j] = w[j][i] = INF;
}
}
return ;
}
int main()
{
int i, j;
int road, cost;
char beg, link;
while(~scanf("%d", &n), n)
{
init();
for(i = 1; i < n; i++)
{
getchar();
scanf("%c %d", &beg, &road);
while(road--)
{
scanf(" %c %d", &link, &cost); //输入的数据处理,%c前面有空格。
w[i][link-'A'+1] = w[link-'A'+1][i] = cost;
}
}
printf("%d\n", Prim(1));
}
return 0;
}
#include <stdlib.h>
#include <string.h>
using namespace std;
const int SIZE = 110;
const int INF = 0x0fffffff;
int w[SIZE][SIZE];
int v[SIZE], d[SIZE];
int n;
int Prim(int src)
{
int i, j;
int tot = 0;
memset(v, 0, sizeof(v));
for(i = 1; i <= n ; i++) d[i] = (i == src)? 0:INF;
for(i = 1; i <= n; i++) //一次循环找出一条边。第一次不算。
{
int x, m = INF;
for(int y = 1; y <= n; y++) if(!v[y] && m >= d[y]) m = d[x=y];
v[x] = 1;
tot += m;
for(int y = 1; y <= n; y++) if(!v[y]) d[y] <?= w[x][y];
}
return tot;
}
void init()
{
int i, j;
for(i = 1; i <= SIZE; i++)
{
for(j = 1; j <= SIZE; j++)
{
w[i][j] = w[j][i] = INF;
}
}
return ;
}
int main()
{
int i, j;
int road, cost;
char beg, link;
while(~scanf("%d", &n), n)
{
init();
for(i = 1; i < n; i++)
{
getchar();
scanf("%c %d", &beg, &road);
while(road--)
{
scanf(" %c %d", &link, &cost); //输入的数据处理,%c前面有空格。
w[i][link-'A'+1] = w[link-'A'+1][i] = cost;
}
}
printf("%d\n", Prim(1));
}
return 0;
}