码迷,mamicode.com
首页 > 其他好文 > 详细

最大生成树 - 堆优化

时间:2017-11-09 11:54:15      阅读:328      评论:0      收藏:0      [点我收藏+]

标签:continue   tin   inf   priority   堆优化   printf   pre   friend   print   

const int inf = 1<<29;
int n, m;
int edge[1005][1005];
int d[1005];
bool vis[1005];

struct node
{
    int v, c;
    node(int _v, int _c):v(_v), c(_c){}
    friend bool operator< (node n1, node n2){
        return n1.c < n2.c;
    }
};
int ans;
void prim(){
    ans = inf;
     priority_queue<node>que;
    for(int i = 1; i <= n; i++){
        d[i] = edge[1][i];
        if (d[i]) que.push(node(i, d[i]));
    }
    d[1] = inf;
    memset(vis, false, sizeof(vis));
   
    
    while(!que.empty()){
        node tem = que.top();
        que.pop();
        
        int v = tem.v;
        int c = tem.c;
        ans = min(ans, c);
        if (v == n) return;
        if (vis[v]) continue;
        vis[v] = true;
        
        for(int i = 1; i <= n; i++){
            if (!vis[i] && edge[v][i] > d[i]){
                d[i] = edge[v][i];
                que.push(node(i, d[i])); 
            }
        }
    }
}

int main() {
    int t;
    int a, b, c;
    int k = 1;
    
    cin >> t;
    while(t--){
        scanf("%d%d", &n, &m);
        memset(edge, 0, sizeof(edge)); 
        for(int i = 1; i <= m; i++){
            scanf("%d%d%d", &a, &b, &c);
            edge[a][b] = edge[b][a] = c;        
        }
        prim();
        printf("Scenario #%d:\n", k++);
        printf("%d\n\n", ans);
    }

    return 0;
}

 

最大生成树 - 堆优化

标签:continue   tin   inf   priority   堆优化   printf   pre   friend   print   

原文地址:http://www.cnblogs.com/ccut-ry/p/7807777.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!