hdu 3371 Connect the Cities(最小生成树)

简介:

题目:http://acm.hdu.edu.cn/showproblem.php?pid=3371

984ms风险飘过~~~

复制代码
/************************************************************************/
/*     
        hdu  Connect the Cities
        最小生成树
        题目大意:最小生成树,题目很长,题意很简单就是最小生成树。关键是构建图
*/
/************************************************************************/

#include <stdio.h>
#include <string.h>
#include <algorithm>
#include <math.h>

#define MAX 0xfffffff

const int N = 501;
int map[N][N];
int vis[N];
int mark[N];
int num,n;

void build_map()
{
    int m,k;
    int q,p,c;
    int t;

    scanf("%d%d%d",&n,&m,&k);
    for (int i = 1; i <= n; i++)
    for (int j = i; j <= n; j++)
    map[i][j] = map[j][i] = ((i==j)?0:MAX);

    for (int i = 0; i < m; i++)
    {
        scanf("%d%d%d",&p,&q,&c);
        if (map[p][q] > c)
        {
            map[p][q] = map[q][p] = c;
        }
        
    }
    while(k--)
    {
        scanf("%d",&t);
        for (int i = 0; i < t; i++)
        {
            scanf("%d",&mark[i]);
            for (int j = 0; j < i; j++)
            {
                map[mark[j]][mark[i]] = map[mark[i]][mark[j]] = 0;
            }
        }
    }
}

int prim()
{
    int t = n;
    int sum = 0;
    int min,k;
    vis[0] = 1;
    while(--t)
    {
        min = MAX;
        for(int i = 2; i <= n; i++)
        {
            if (vis[i] != 1 && map[1][i] < min)
            {
                min = map[1][i];
                k = i;
            }
        }
        if(min == MAX)break;
        vis[k] = 1;
        sum += min;
        for (int i = 2; i <= n; i++)
        {
            if (vis[i] != 1 && map[k][i] < map[1][i])
            map[1][i] = map[k][i];
        }
    }
    return t==0?sum:-1;
}


int main()
{
    scanf("%d",&num);
    while(num--)
    {
        build_map();
        memset(vis,0,sizeof(vis));
        printf("%d\n",prim());
    }
    return 0;
}
复制代码

 









本文转自NewPanderKing51CTO博客,原文链接:http://www.cnblogs.com/newpanderking/p/3253094.html ,如需转载请自行联系原作者

相关文章
|
8月前
|
Java
hdu-1869-六度分离(dijkstra)
hdu-1869-六度分离(dijkstra)
49 0
|
8月前
最短路径问题(HDU3790)
最短路径问题(HDU3790)
|
8月前
|
算法 定位技术
The Unique MST(最小生成树的唯一路径)
The Unique MST(最小生成树的唯一路径)
HDU7050.Link with Limit(有向图tarjan找环)
HDU7050.Link with Limit(有向图tarjan找环)
154 0
|
算法
Prim Algoritm(最小生成树)
Prim Algorithm。这个算法可以分为下面几个步骤: 将顶点集V分成两个集合A和B,其中集合A表示目前已经在MST中的顶点,而集合B则表示目前不在MST中的顶点。 在B寻找与集合A连通的最短的边(u,v),将这条边加入最小生成树中。
869 0
|
算法 机器学习/深度学习