zoukankan      html  css  js  c++  java
  • HDU 1879 继续畅通工程

    链接:http://acm.hdu.edu.cn/showproblem.php?pid=1879


    并查集+优先队列...用cin会超时...TLE了好几次


    #include <iostream>
    #include<queue>
    #include<cstdio>
    #define MAX_N 105
    using namespace std;
    class rode
    {
    public:
        int from;
        int to;
        int cost;
        int sign;
    };
    
    int par[MAX_N];
    int high[MAX_N];
    int c;          //记录当前有几个集合
    bool operator <(rode a,rode b)
    {
        return a.cost>b.cost;
    }
    priority_queue <rode> data;
    void init(int n)        //初始化
    {
        c=n;
        for(int i=1;i<=n;i++)
        {
            par[i]=i;
            high[i]=0;
        }
    }
    int ifind(int x)
    {
        if(par[x]==x)
            return x;
        else
            return par[x]=ifind(par[x]);
    }
    void unite(int x,int y)
    {
        x=ifind(x);
        y=ifind(y);
        if(x==y)
            return;
        if(high[x]<high[y])
            par[x]=y;
        else
        {
             par[y]=x;
             if(high[x]==high[y])
                high[x]++;
        }
        c--;
    
    }
    bool same (int x,int y)
    {
        return ifind(x)==ifind(y);
    }
    void readrode(int n)
    {
        rode t;
        while(!data.empty())
            data.pop();
    
        for(int i=0; i<n*(n-1)/2; i++)
        {
            scanf("%d%d%d%d",&t.from,&t.to,&t.cost,&t.sign);
            if(t.sign)      //如果路已修好
                unite(t.from,t.to);
            else            //未修好,则加入队列
                data.push(t);
        }
    }
    int markrode(void)
    {
        int sum=0;
        rode t;
        while(!data.empty()&&c>1)
        {
            t=data.top();
            data.pop();
            if(!same(t.from,t.to))
            {
                unite(t.from,t.to);
                sum+=t.cost;
            }
    
        }
        return sum;
    
    }
    
    int main()
    {
        int n;
        while(scanf("%d",&n)&&n)
        {
            init(n);
            readrode(n);
            cout<<markrode()<<endl;
    
        }
    
        return 0;
    }
    


  • 相关阅读:
    apache的源代码编译安装
    python学习笔记(五) 200行实现2048小游戏
    python学习笔记(四) 思考和准备
    python学习笔记(三)高级特性
    python自学笔记(二)
    python自学笔记(一)
    redis 配置和使用(C++)
    汇编基础最后一篇--机器语言指令
    汇编语言学习笔记(六)
    网络编程学习方法和图书推荐
  • 原文地址:https://www.cnblogs.com/frankM/p/4399494.html
Copyright © 2011-2022 走看看