hdu2122

#include<stdlib.h>
#include<string.h>
#include<stdio.h>
#include<math.h>
#include<queue>
#define MAXN 1005

using namespace std;

int root[MAXN];

struct edge{
    int head;
    int tail;
    int cost;
    friend bool operator< (const edge &e1,const edge &e2){
        return e1.cost > e2.cost;
    }
};
priority_queue<edge> qn;

int findroot(int index){
    if(root[index] == -1)
        return index;
    else
        return root[index] = findroot(root[index]);
}
int kruskal(){
    int count;
    edge ebuf;
    count=0;
    while(!qn.empty()){
        ebuf = qn.top();
        qn.pop();
        int bufroot1 = findroot(ebuf.head);
        int bufroot2 = findroot(ebuf.tail);
        if(bufroot1 != bufroot2){
            root[bufroot1] = bufroot2;
            count+=ebuf.cost;
        }
    }
    return count;
}
int main(){
    int i;
    int n;
    int m;
    int u,v,cost,complete;
    edge edgebuf;
    
    freopen("in.txt","r",stdin);
    freopen("out.txt","w",stdout);

    while(scanf("%d",&n)!=EOF){    
        for(i=0;i<n;i++){
            root[i]=-1;
        }
        scanf("%d",&m);
        for(i=0;i<m;i++){
            scanf("%d %d %d",&u,&v,&cost);
            edgebuf.head = u;
            edgebuf.tail = v;
            edgebuf.cost = cost;
            qn.push(edgebuf);
        }
        int costbuf = kruskal();
        int count;
        count=0;
        for(i=0;i<n;i++){
            if(root[i] == -1)
                count++;
        }
        if(count == 1)
            printf("%d\n\n",costbuf);
        else
            printf("impossible\n\n");
    }
    return 0;
}

 

转载于:https://www.cnblogs.com/kahreman/archive/2013/04/30/3051508.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值