zoukankan      html  css  js  c++  java
  • [原]基础最小生成树代码留存


    最小生成树的水题,在这里讲一下kruskal算法,权当温故:

    Kruskal的关键在于对于边权从小到大排序,然后在“排好序的基础上”用并查集判断 E(u , v)上两个顶点u,v 是否在同一个连通分量中,不在,则记录该边权,合并两点。为什么要排序呢?假设从无到有建立一棵最小生成树,则对于从小到大排好序的边集,最先加入合并(加入条件参照上一句话)的N-1条边一定是最优的。

    这里,带路径压缩的并查集操作,可以高效地合并、判断两个点是否在同一个连通分量中,时间可视为常数级的。

    ========Hi~ o(* ̄▽ ̄*)ブ ===========我是呆萌の分割线=================



    ① HDU1102-Constructing Roads【最小生成树-kruskal(water)】

    题意就不翻译了。

    关于这题的AC代码如下,不是很规范的Kruskal:

    {CSDN:CODE:328914}


    之前由于忘了把vector  clear,WA了N+1次。。。。T^T血的教训惹~~~


    ②HDU-1863-畅通工程-【基础最小生成树-Kruskal】

    AC代码:

    {CSDN:CODE:323874}



    ③HDU-1233-还是畅通工程-【基础最小生成树-Kruskal】

    AC代码:

    {CSDN:CODE:328913}

    ④HDU-1875 -畅通工程再续---基础最小生成树★

    AC代码:

    {CSDN:CODE:328915}


    作者:u011652573 发表于2014-5-2 21:32:36 原文链接
    阅读:36 评论:0 查看评论
  • 相关阅读:
    asp.net Core 中间件Hello world
    MVC2 ,MVC3 ,MVC4,MVC5的区别,EF的各个版本的区别;LocalDB是个啥
    EF6 MVC5译文
    发布一个C++版本的ORM库SmartDB
    ORM
    Git图形化界面客户端大汇总
    Model工具
    HTTP协议的8种请求类型介绍
    五大主流数据库模型
    店铺装修——进阶模块介绍
  • 原文地址:https://www.cnblogs.com/ZiningTang/p/3834743.html
Copyright © 2011-2022 走看看