zoukankan      html  css  js  c++  java
  • POJ 1258 最小生成树

    23333333333

    完全是道水题。因为是偶自己读懂自己做出来的。。T_T、prim的模板题水过。

    DESCRIPTION:
    John竞选的时候许诺会给村子连网。现在给你任意两个村子之间的距离。让你求任意两个村庄是连通的所需要的网线。就是求最小生成树的权值。

    附代码:

    #include<stdio.h>
    #include<iostream>
    #include<string.h>
    #include<string>
    #include<algorithm>
    #define inf 0x1f1f1f1f
    using namespace std;

    int map[210][210];
    int n;

    int prim()
    {
        int low[210], vis[210];
        int min, res = 0, p;
        memset(vis, 0, sizeof(vis));
        vis[0] = 1;
        for (int i=1; i<n; ++i)
        {
            low[i] = map[0][i];
        }
        for (int i=1; i<n; ++i)  // 循环n-1次 找最小生成树的n-1个点
        {
            min = inf;
            p = -1;
            for (int j=0; j<n; ++j)
            {
                if (vis[j] == 0 && min > low[j])
                {
                    min = low[j];
                    p = j;
                }
            }
            if (res == inf)
            return -1;
            res += min;
            vis[p] = 1;
            for (int j=0; j<n; ++j)
            {
                if (vis[j] == 0 && low[j] > map[p][j])
                {
                    low[j] = map[p][j];
                }
            }
        }
        return res;
    }

    int main()
    {
        while(cin >> n)
        {
            memset(map, 0, sizeof(map));
            for (int i=0; i<n; ++i)
            {
                for (int j=0; j<n; ++j)
                cin >> map[i][j];
            }
            int ans = prim();
            cout << ans << endl;
        }
        return 0;
    }

  • 相关阅读:
    VS2010 配置驱动开发环境
    C函数调用与入栈顺序
    Ecshop后台流量分析地区分布的地名全是乱码
    使用.net程序发送邮件代码
    齐博系统出现此文件不可写:cache/label_cache/index_0_8_0_0_1_6539c.php
    UCHOME中链接前多了link.php?url=,如何去除
    discuz7.2 修改数据调用中日期格式
    php设置和获取cookie
    删除数据库所有存储过程的SQL语句
    docker搭建skywalking 8.7简明笔记 海口
  • 原文地址:https://www.cnblogs.com/icode-girl/p/4567046.html
Copyright © 2011-2022 走看看