GOOD NIGHT

诸位,这是最小生成树的模板(掌声)

最小生成树

以下是题目链接:FOR——MIKU

代码如下

/*
并查集可以解决最小生成树的问题 因为并查集可以完成高效的合并 但是,以下代码依赖于一个重要前提 ,就是每两棵树之间只有一根线,不然,以下代码绝对不行 证明: 在A,B之间有三条边,边值为1,2,3;
按照以下思路,排序后是3,2,1;
当我们处理3时,我们把A,B合进了一个集中;
然而,当我们处理到2,1时,我们会检查到A,B已经在了同一个集合!!!!!!!
所以说我们的代码不会删除2,1这两条边!!!!!!!
这样就从根本上否决了最小生成树,因为两点之间有2条及以上边 */
#include<iostream>
#include <algorithm>
#include<cstdio>
#include<algorithm>
#include<algorithm>
#include<algorithm>
#include<ctime>
using namespace std;
int n,k,fa[]; int sum; struct bian{
int start;
int last;
int diss;
}biann[]; /*
这个并查集就是依赖于只有一条边,从大到小按权值删 */
bool cmp(bian x,bian y)
{
return x.diss<y.diss;
} int find(int x)
{
if(fa[x]!=x)
return find(fa[x]);
return x;
} int main()
{
cin>>n>>k;
for(int i=;i<=n;++i)//并查集部分
fa[i]=i;
for(int i=;i<=k;++i)
{
cin>>biann[i].start>>biann[i].last>>biann[i].diss;
sum+=biann[i].diss;//得到权值和,因为用并查集做题是删边
}//存图部分
sort(biann+,biann++k,cmp);
for(int i=;i<=k;++i)//并查集部分
{//以下部分仅依赖于前提
int r1=find(biann[i].start);
int r2=find(biann[i].last);
if(r1 != r2)
{//这部分有点贪心了,因为只要搜到,在一块,就一定是最短了,因为只有一条边
fa[r1]=r2;
sum-=biann[i].diss;//并查集是删边
}
}
cout<<sum; return ; }

P2820 局域网的更多相关文章

  1. 最小生成树 & 洛谷P3366【模板】最小生成树 & 洛谷P2820 局域网

    嗯... 理解生成树的概念: 在一幅图中将所有n个点连接起来的n-1条边所形成的树. 最小生成树: 边权之和最小的生成树. 最小瓶颈生成树: 对于带权图,最大权值最小的生成树. 如何操作? 1.Pri ...

  2. 洛谷——P2820 局域网

    P2820 局域网 题目背景 某个局域网内有n(n<=100)台计算机,由于搭建局域网时工作人员的疏忽,现在局域网内的连接形成了回路,我们知道如果局域网形成回路那么数据将不停的在回路内传输,造成 ...

  3. 洛谷 P2820 局域网

    题目链接 https://www.luogu.org/problemnew/show/P2820 题目背景 某个局域网内有n(n<=100)台计算机,由于搭建局域网时工作人员的疏忽,现在局域网内 ...

  4. 洛谷P2820 局域网 (最小生成树)

    题目链接:https://www.luogu.org/problemnew/show/P2820 题目背景 某个局域网内有n(n<=100)台计算机,由于搭建局域网时工作人员的疏忽,现在局域网内 ...

  5. P2820 局域网 洛谷

    https://www.luogu.org/problem/show?pid=2820 题目背景 某个局域网内有n(n<=100)台计算机,由于搭建局域网时工作人员的疏忽,现在局域网内的连接形成 ...

  6. 洛谷 P2820 局域网x

    题目背景 某个局域网内有n(n<=100)台计算机,由于搭建局域网时工作人员的疏忽,现在局域网内的连接形成了回路,我们知道如果局域网形成回路那么数据将不停的在回路内传输,造成网络卡的现象.因为连 ...

  7. 洛谷P2820 局域网

    #include<bits/stdc++.h> using namespace std; ; ; int n,k,sum,tot; struct node{ int cnt,fa; }f[ ...

  8. NOIp2017囤题计划

    马上就要NOIp2017了,应该囤些题目吧…… 好的这只是一个开始 upd - 11.5 1.p1576 最小花费 无向图,dijisktra 2.p1339 [USACO09OCT]热浪Heat W ...

  9. 洛谷P3366【模板】最小生成树-克鲁斯卡尔Kruskal算法详解附赠习题

    链接 题目描述 如题,给出一个无向图,求出最小生成树,如果该图不连通,则输出orz 输入输出格式 输入格式: 第一行包含两个整数N.M,表示该图共有N个结点和M条无向边.(N<=5000,M&l ...

随机推荐

  1. 【Alpha】事后分析

    Alpha阶段终于告一段落,我们的团队也完整经历了从提出设想.用户需求分析,到开发.测试,再到部署上线.推广的流程."葫芦娃不想写代码"团队还是较出色地完成了Alpha阶段的工作, ...

  2. Spring _day01_下载、概述、监听器

    Spring:SE/EE开发的一站式框架. ​ .一站式框架:有EE开发的每一层解决方案. ​ . WEB层 :SpringMVC ​ . Service层 :Spring的Bean管理,Spring ...

  3. JAVA常用异常类

    算数异常类:   ArithmeticExecption 空指针异常类:    NullPointerException 指定类不存在:    ClassNotFoundException 字符串转换 ...

  4. iis设置http重置到https

    http://www.cnblogs.com/tangge/p/4259749.html 1.购买SSL证书,参考:http://www.cnblogs.com/yipu/p/3722135.html ...

  5. 小白的Redis学习(一)-SDS简单动态字符串

    本文为读<Redis设计与实现>的记录.该书以Redis2.9讲解Redis相关内容.请注意版本差异. Redis使用C语言实现,他对C语言中的char类型数据进行封装,构建了一种简单动态 ...

  6. xss过滤代码

    #!/usr/bin/env python # -*- coding:utf-8 -*- from bs4 import BeautifulSoup class XSSFilter(object): ...

  7. selenium中的上传文件

    # 上传文件driver.find_element_by_xpath("//input[@value='上传文件']").send_keys(r"C:\Users\YKD ...

  8. bll

    string str = ConfigurationManager.AppSettings["DBName"].ToString(); public Studal ss() { A ...

  9. RobotFramework之Run Keyword的使用

    RobotFramework之Run Keyword的使用        在之前写的RobotFramework(二)中有提到过这个Run Keyword关键字的使用,但是再做检查判断的时候,发现它的 ...

  10. my first homepage

    <!DOCTYPE html><html><head><style type="text/css">p{ text-indent:2 ...