Problem 1566 - C - Spanning Tree

给出一个联通图,然后每次加一条边,每次需要求最小生成树

  1 #include <iostream>
2 #include <cstdio>
3 #include <cstring>
4 #include <cmath>
5 #include <algorithm>
6 #include <string>
7 #include <vector>
8 #include <set>
9 #include <map>
10 #include <stack>
11 #include <queue>
12 #include <sstream>
13 #include <iomanip>
14 using namespace std;
15 typedef long long LL;
16 const int INF = 0x4fffffff;
17 const double EXP = 1e-5;
18 const int MS = 5005;
19 const int SIZE = 100005;
20
21 struct edge
22 {
23 int u,v,w;
24 bool operator <(const edge &a)const
25 {
26 return w<a.w;
27 }
28 }edges[SIZE];
29
30 int n,m,q,ans,cnt;
31
32 int fa[MS];
33
34 int find(int x)
35 {
36 int s;
37 for(s=x;fa[s]>=0;s=fa[s]);
38 while(s!=x)
39 {
40 int tmp=fa[x];
41 fa[x]=s;
42 x=tmp;
43 }
44 return s;
45 }
46
47 void merge(int u,int v)
48 {
49 int f1=find(u);
50 int f2=find(v);
51 int tmp=fa[f1]+fa[f2];
52 if(fa[f1]>fa[f2])
53 {
54 fa[f1]=f2;
55 fa[f2]=tmp;
56 }
57 else
58 {
59 fa[f2]=f1;
60 fa[f1]=tmp;
61 }
62 }
63
64
65 bool flag[MS];
66
67 int MST()
68 {
69 int num=0,sum=0;
70 sort(edges,edges+cnt);
71 memset(fa,0xff,sizeof(fa));
72 memset(flag,0,sizeof(flag));
73 for(int i=0;i<cnt;i++)
74 {
75 int u=edges[i].u;
76 int v=edges[i].v;
77 int w=edges[i].w;
78 if(find(u)!=find(v))
79 {
80 merge(u,v);
81 flag[i]=1;
82 sum+=w;
83 num++;
84 }
85 if(num>=n-1)
86 break;
87 }
88 num=0;
89 for(int i=0;i<cnt;i++)
90 if(flag[i])
91 edges[num++]=edges[i];
92 cnt=num;
93 return sum;
94 }
95
96 int main()
97 {
98 int u,v,w;
99 while(scanf("%d%d%d",&n,&m,&q)!=EOF)
100 {
101 cnt=0;
102 for(int i=0;i<m;i++)
103 {
104 scanf("%d%d%d",&u,&v,&w);
105 if(u==v)
106 continue;
107 edges[cnt].u=u;
108 edges[cnt].v=v;
109 edges[cnt++].w=w;
110 }
111 ans=MST();
112 for(int i=0;i<q;i++)
113 {
114 scanf("%d%d%d",&u,&v,&w);
115 if(u==v)
116 {
117 printf("%d\n",ans);
118 }
119 else
120 {
121 edges[cnt].u=u;
122 edges[cnt].v=v;
123 edges[cnt++].w=w;
124 ans=MST();
125 printf("%d\n",ans);
126 }
127 }
128 }
129 return 0;
130 }

Problem 1566 - C - Spanning Tree 动态最小生成树的更多相关文章

  1. 【HDU 4408】Minimum Spanning Tree(最小生成树计数)

    Problem Description XXX is very interested in algorithm. After learning the Prim algorithm and Krusk ...

  2. Geeks : Kruskal’s Minimum Spanning Tree Algorithm 最小生成树

    版权声明:本文作者靖心,靖空间地址:http://blog.csdn.net/kenden23/.未经本作者同意不得转载. https://blog.csdn.net/kenden23/article ...

  3. 说说最小生成树(Minimum Spanning Tree)

    minimum spanning tree(MST) 最小生成树是连通无向带权图的一个子图,要求 能够连接图中的所有顶点.无环.路径的权重和为所有路径中最小的. graph-cut 对图的一个切割或者 ...

  4. HDU 4408 Minimum Spanning Tree 最小生成树计数

    Minimum Spanning Tree Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Ot ...

  5. 最小生成树(Minimum Spanning Tree)——Prim算法与Kruskal算法+并查集

    最小生成树——Minimum Spanning Tree,是图论中比较重要的模型,通常用于解决实际生活中的路径代价最小一类的问题.我们首先用通俗的语言解释它的定义: 对于有n个节点的有权无向连通图,寻 ...

  6. 数据结构与算法分析–Minimum Spanning Tree(最小生成树)

    给定一个无向图,如果他的某个子图中,任意两个顶点都能互相连通并且是一棵树,那么这棵树就叫做生成树(spanning tree). 如果边上有权值,那么使得边权和最小的生成树叫做最小生成树(MST,Mi ...

  7. Educational Codeforces Round 3 E. Minimum spanning tree for each edge 最小生成树+树链剖分+线段树

    E. Minimum spanning tree for each edge time limit per test 2 seconds memory limit per test 256 megab ...

  8. 【算法】关于图论中的最小生成树(Minimum Spanning Tree)详解

    本节纲要 什么是图(network) 什么是最小生成树 (minimum spanning tree) 最小生成树的算法 什么是图(network)? 这里的图当然不是我们日常说的图片或者地图.通常情 ...

  9. Codeforces Educational Codeforces Round 3 E. Minimum spanning tree for each edge LCA链上最大值

    E. Minimum spanning tree for each edge 题目连接: http://www.codeforces.com/contest/609/problem/E Descrip ...

随机推荐

  1. 把一个整体目标设置成多个分阶段目标,完成了一个目标后,就相当于一件事OVER

    如果事情有变坏的可能,不管这种可能性有多小,它总会发生 . 一.任何事都没有表面看起来那么简单:二.所有的事都会比你预计的时间长:三.会出错的事总会出错:四.如果你担心某种情况发生,那么它就一定会发生 ...

  2. 036.Python的TCP语法

    TCP语法 1 建立一个socket对象 import socket sk = socket.socket() print (sk) 执行 [root@node10 python]# python3 ...

  3. 自用Chrome插件推荐【附教程及下载】

    自用Chrome插件推荐[附教程及下载] 豆子   1,675 人赞同了该文章 2019.11.03更新 原文同步发布在我的个人博客 Chrome插件自用​blog.douzi.work 都是我自己一 ...

  4. IT菜鸟之路由器基础配置(静态、动态、默认路由)

    路由器:连接不同网段的设备 企业级路由和家用级路由的区别: 待机数量不同(待机量) 待机量:同时接通的终端设备的数量 待机量的值越高,路由的性能越好 别墅级路由,表示信号好,和性能无关 交换机:背板带 ...

  5. SpringMVC Web 相对路径与绝对路径

    基本概念 绝对路径 绝对路径就是你的主页上的文件或目录在硬盘上真正的路径,(URL和物理路径) 例如: C:\xyz\test.txt 代表了 test.txt 文件的绝对路径. http://www ...

  6. Heap Size 与 Stack Size

    Heap Size:如果没有用到标准库的malloc,就是废物,纯属浪费内存,所以直接设置为0即可: Stack Size :最大的可读写变量的大小即可:

  7. 常见判断错误 (Day_30)

    写给自己的话: 这是一个卡了我小半天的BUG,也是一个很低端的BUG,写篇博客吧,以后回来看看,会发现曾经的自己是如何的菜. 同样,以此记录我的进步 步入正题,这是我实现多条件分页时遇到的一个BUG, ...

  8. mysql事务实现方式

    事务是由一组SQL语句组成的逻辑处理单元,事务具有4属性,通常称为事务的ACID属性. 原子性(Actomicity):事务是一个原子操作单元,其对数据的修改,要么全都执行,要么全都不执行. 由und ...

  9. Redux 原理和简单实现

    前端开发中React + Redux 是大部分项目的标配,Redux也是我喜欢的库之一,他的源码也拜读过几遍,每次都有很多收获,尤其他的中间件设计模式,对自己封装一些库提供了思想上的指导. Redux ...

  10. 删除win10系统下文件默认打开方式的关联-win10配置

    现象 文件默认打开方式错误 链接到老的打开软件 无法图形化重定义关联软件 文件图标关联异常 1. 打开注册表编辑器 win + R regedit 2. 修改注册表 找到以下注册表路径,找到指定的文件 ...