太久没写最小生成树了,快忘光了。这几天回顾了一下

  • 最小生成树一·Prim算法

    AC G++ 369ms 17MB
    #include "cstdio"
    using namespace std;
    const int INF = 0x3f3f3f3f;
    int road[][];
    int dis[], n, ans;
    bool vis[];
    void prim() {
    int v, mn;
    for (int i = ; i <= n; i++) {
    dis[i] = road[][i];
    }
    vis[] = true;
    for (int i = ; i < n; i++) {
    mn = INF;
    for (int j = ; j <= n; j++) {
    if (!vis[j] && dis[j] < mn) {
    mn = dis[j];
    v = j;
    }
    }
    ans += dis[v];
    vis[v] = true;
    for (int j = ; j <= n; j++) {
    if (!vis[j] && dis[j] > road[v][j]) {
    dis[j] = road[v][j];
    }
    /*
    这个if改成如下写法就变成Dijkstra算法求最短路了
    if (!vis[j] && dis[j] > dis[v] + road[v][j]) {
    dis[j] = dis[v] + road[v][j];
    }
    */
    }
    }
    }
    int main() {
    scanf("%d", &n);
    for (int i = ; i <= n; i++) {
    for (int j = ; j <= n; j++) {
    scanf("%d", &road[i][j]);
    }
    }
    prim();
    printf("%d\n", ans);
    return ;
    }

    理解了Dijkstra看这个就很容易了,改一下if语句多加一个ans就是了;

  • 最小生成树二·Kruscal算法
    AC G++ 342ms 17MB
    #include "bits/stdc++.h"
    using namespace std;
    typedef long long LL;
    const int INF = 0x3f3f3f3f;
    // 并查集
    int pre[];
    struct Road{
    int s, e, v;
    }road[];
    bool cmp(Road n, Road m) {
    return n.v < m.v;
    }
    int find(int id) {
    if (pre[id] == ) {
    return id;
    }
    return pre[id] = find(pre[id]);
    }
    int main() {
    int n, m, ans = ;
    scanf("%d%d", &n, &m);
    for (int i = ; i < m; i++) {
    scanf("%d%d%d", &road[i].s, &road[i].e, &road[i].v);
    }
    sort (road, road + m, cmp);
    // 用n - 1条边可以联通n个点,所以当n == 1的时候退出循环
    for (int i = ; n != ; i++) {
    int s = find(road[i].s);
    int e = find(road[i].e);
    if (s != e) {
    pre[s] = e;
    n--;
    ans += road[i].v;
    }
    }
    printf("%d\n", ans);
    return ;
    }

    Kruscal算法有点贪心的意思在里面吧,每次取最短的边,当n个点被联通时退出循环

  • 最小生成树三·堆优化的Prim算法
    AC G++ 436ms 24MB
    #include "bits/stdc++.h"
    using namespace std;
    typedef long long LL;
    typedef pair<int, int> PII;
    const int INF = 0x3f3f3f3f;
    const int MAXN = 1e5 + ;
    /*
    road[i].first 存放以i为顶点的边的另一个顶点
    road[i].second 存放以i为顶点的边的长度
    */
    vector<PII> road[MAXN];
    int dis[MAXN];
    int ans;
    bool vis[MAXN];
    void prim() {
    // q表示就目前状态可以花费q.top.first的代价去联通q.top.second这个点
    priority_queue<PII, vector<PII>, greater<PII> > q;
    memset(dis, INF, sizeof(dis));
    q.push({, });
    while (!q.empty()) {
    int id = q.top().second;
    if (vis[id]) {
    // 如果id已经被联通,直接continue
    q.pop();
    continue;
    } else {
    // 否则由于优先列队的排序,q.top.first一定是最小代价
    ans += q.top().first;
    q.pop();
    }
    vis[id] = true;
    for (auto i : road[id]) {
    if (i.second < dis[i.first]) {
    dis[i.first] = i.second;
    q.push({i.second, i.first});
    }
    }
    }
    }
    int main() {
    int n, m;
    int u, v, w;
    scanf("%d%d", &n, &m);
    while (m--) {
    scanf("%d%d%d", &u, &v, &w);
    road[u].push_back({v, w});
    road[v].push_back({u, w});
    }
    prim();
    printf("%d\n", ans);
    return ;
    }

    果然还是和dijkstra很像啊,仿照dijkstra的堆优化就好了。这种建图的方法倒是比原先用的链式前向星好写多了。

最小生成树 HihoCoder-1097、1098、1109(最小生成树算法)的更多相关文章

  1. MST最小生成树及Prim普鲁姆算法

    MST在前面学习了Kruskal算法,还有一种算法叫做Prim的.这两者的区别是Prim算法适合稠密图,比如说鸟巢这种几乎所有点都有相连的图.其时间复杂度为O(n^2),其时间复杂度与边的数目无关:而 ...

  2. 【数据结构】 最小生成树(四)——利用kruskal算法搞定例题×3+变形+一道大水题

    在这一专辑(最小生成树)中的上一期讲到了prim算法,但是prim算法比较难懂,为了避免看不懂,就先用kruskal算法写题吧,下面将会将三道例题,加一道变形,以及一道大水题,水到不用高级数据结构,建 ...

  3. 【数据结构】最小生成树之prim算法和kruskal算法

    在日常生活中解决问题经常需要考虑最优的问题,而最小生成树就是其中的一种.看了很多博客,先总结如下,只需要您20分钟的时间,就能完全理解. 比如:有四个村庄要修四条路,让村子能两两联系起来,这时就有最优 ...

  4. 最小生成树——Kruskal(克鲁斯卡尔)算法

    [0]README 0.1) 本文总结于 数据结构与算法分析, 源代码均为原创, 旨在 理解 Kruskal(克鲁斯卡尔)算法 的idea 并用 源代码加以实现: 0.2)最小生成树的基础知识,参见 ...

  5. hiho一下 第二十九周 最小生成树三·堆优化的Prim算法【14年寒假弄了好长时间没搞懂的prim优化:prim算法+堆优化 】

    题目1 : 最小生成树三·堆优化的Prim算法 时间限制:10000ms 单点时限:1000ms 内存限制:256MB 描述 回到两个星期之前,在成功的使用Kruscal算法解决了问题之后,小Ho产生 ...

  6. hihocoder 1097 最小生成树一·Prim算法

    #1097 : 最小生成树一·Prim算法 时间限制:10000ms 单点时限:1000ms 内存限制:256MB 描述 最近,小Hi很喜欢玩的一款游戏模拟城市开放出了新Mod,在这个Mod中,玩家可 ...

  7. hihoCoder#1109 最小生成树三·堆优化的Prim算法

    原题地址 坑了我好久...提交总是WA,找了个AC代码,然后做同步随机数据diff测试,结果发现数据量小的时候,测试几十万组随机数据都没问题,但是数据量大了以后就会不同,思前想后就是不知道算法写得有什 ...

  8. HihoCoder 1097 Prim算法

    1097 : 最小生成树一·Prim算法 时间限制:10000ms 单点时限:1000ms 内存限制:256MB 描述 最近,小Hi很喜欢玩的一款游戏模拟城市开放出了新Mod,在这个Mod中,玩家可以 ...

  9. 最小生成树之 prim算法和kruskal算法(以 hdu 1863为例)

    最小生成树的性质 MST性质:设G = (V,E)是连通带权图,U是V的真子集.如果(u,v)∈E,且u∈U,v∈V-U,且在所有这样的边中, (u,v)的权c[u][v]最小,那么一定存在G的一棵最 ...

随机推荐

  1. 19 docker 多机器通信

    1. 本章实验 2. 环境搭建 1.编写 Vagrantfile 并创建虚拟机 并虚拟机node1绑定外部 192.168.205.10:8888 node2绑定外部 192.168.205.10:9 ...

  2. jquery如何获取div下ul的某个li

    $('div ul').each(function(){ alert($(this).find('li').eq(x)) }) $("div ul li:eq(1)")// $(& ...

  3. 搭建zookeeper环境

    zookeeper是一个强一致的分布式数据库,由多个节点共同组成一个分布式集群,挂掉任意一个节点,数据库仍然可以正常工作. 独立模式 下载zookeeper打包文件,并进行解压 ➜ ~ tar -xv ...

  4. curl命令简介

    curl 文件传输工具 参数: -c --cokie-jar: 将cookie写入到文件 -b --cokie: 从文件中读取cookie -C --continue-at: 断点续传 -d --da ...

  5. pandas在指定列插入数据

    import pandas as pd import numpy as np df = pd.DataFrame(np.arange(15).reshape(5, 3), columns=['a', ...

  6. dfs+剪枝 poj1011

    Sticks Time Limit: 1000MS   Memory Limit: 10000K Total Submissions: 113547   Accepted: 26078 问题描述 Ge ...

  7. P2P平台疯狂爆雷后,你的生活受到影响了吗?

    最近这段时间P2P爆雷的新闻和报道一直占据着各大财经和科技媒体的重要位置.而据网贷之家数据显示,截至2018年7月底,P2P网贷行业累计平台数量达到6385家(含停业及问题平台),其中问题平台累计为2 ...

  8. Python 进阶 - 面向对象

    Python 面向对象 面向过程 把完成某个需求的所有步骤,从头到尾逐步实现 根据开发需求,将某些功能独立的代码封装成一个又一个函数 最后完成的代码,就是顺序地调用不同的函数 面向过程特点: 注重步骤 ...

  9. LeetCode——542. 01 矩阵

    给定一个由 0 和 1 组成的矩阵,找出每个元素到最近的 0 的距离. 两个相邻元素间的距离为 1 . 示例 1: 输入: 0 0 0 0 1 0 0 0 0 输出: 0 0 0 0 1 0 0 0 ...

  10. centos6.8 yum安装mysql 5.6

    一.检查系统是否安装其他版本的MYSQL数据 #yum list installed | grep mysql #yum -y remove mysql-libs.x86_64 二.安装及配置 # w ...