• HDOJ1233 ( 还是畅通工程 ) 【最小生成树,kruscal】


     以前遇到最小生成树的题目都是用Prim去做,今天第一次用Kruscal做,感觉Kruscal比Prim容易实现多了。

    之前一直听说kruscal用到并查集,以为很神秘,今天做了题目,才发现,原来这就是基本的并查集,并不可怕。

    【有些我们认为很难而不敢触碰的事情,或许并没有那么可怕。】

    Problem : 1233 ( 还是畅通工程 )     Judge Status : Accepted
    RunId : 5936238    Language : C++    Author : qq1203456195
    Code Render Status : Rendered By HDOJ C++ Code Render Version 0.01 Beta
     
     1 #include <cstdio>
     2 #include <cstring>
     3 #include <algorithm>
     4 using namespace std;
     5 #define N 101
     6 typedef struct{
     7     int x,y;
     8     int len;
     9 }EDGE;
    10 int map[N][N],set[N],n;
    11 EDGE edge[N*N];
    12 int cmp(const EDGE& a,EDGE& b)
    13 {
    14     return a.len<b.len;
    15 }
    16 int FindSet(int a)
    17 {
    18     return set[a];
    19 }
    20 void MergeSet(int a,int b)
    21 {
    22     int i;
    23     for (i=1;i<=n;i++)
    24         if(set[i]==a)
    25             set[i]=b;
    26 }
    27 int main()
    28 {
    29     int i,p,sum,m,f,t;
    30     while (scanf("%d",&n),n)//n为村庄个数
    31     {
    32         //初始化map
    33         memset(map,0,sizeof(map));
    34         //最多m条边
    35         m=(n*(n-1))>>1;
    36         //初始化set
    37         for (i=1;i<=n;i++)    set[i]=i;    
    38         //构建map
    39         for (i=0;i<m;i++)    scanf("%d%d%d",&edge[i].x,&edge[i].y,&edge[i].len);
    40         //已经选取的点的个数
    41         p=0;
    42         //路径总长度
    43         sum=0;
    44         //对边进行排序
    45         sort(edge,edge+i,cmp);
    46         for (i=0;i<m&&p!=n;i++)
    47         {
    48             //查找当前边的起始点是否在同一个集合中
    49             f=FindSet(edge[i].x);
    50             t=FindSet(edge[i].y);
    51             if(f!=t)
    52             {
    53                 MergeSet(f,t);
    54                 p++;
    55                 sum+=edge[i].len;
    56             }
    57         }
    58         printf("%d\n",sum);
    59     }
    60     return 0;
    61 }
    字节跳动内推

    找我内推: 字节跳动各种岗位
    作者: ZH奶酪(张贺)
    邮箱: cheesezh@qq.com
    出处: http://www.cnblogs.com/CheeseZH/
    * 本文版权归作者和博客园共有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接,否则保留追究法律责任的权利。

  • 相关阅读:
    JCTF 2014(Reverse)
    JCTF 2014(Misc)
    实验吧CTF题库-密码学(部分)
    第四章 Jinja2模版
    第三章 URL与视图
    flask学习导航主页
    flask调试模式
    rontab踩坑(三):crontab定时任务调度机制与系统时间/时区的不一致
    crontab踩坑(二):Unit crond.service could not be found.
    crontab踩坑(一)
  • 原文地址:https://www.cnblogs.com/CheeseZH/p/2497640.html
Copyright © 2020-2023  润新知