带权匹配是指在最大匹配的基础上,使匹配边的边权和最大。一般有两种写法,一个是KM算法(只针对可以完备匹配的二分图),一个是费用流。 KM算法在稠密图上比费用流更优秀一些,不过应用范围太小,所以还是鼓励大家用费用流。当然啦,作为一种算法KM也是我们需要了解的(况且我不会网络流😄)。 KM算法有个流程 ...
分类:
其他好文 时间:
2019-01-04 19:40:15
阅读次数:
217
算法分析的一般步骤: 1、文字描述:如果一个算法文字描述不清楚,就说明思路不清楚,也不可能写好。 prim算法是实现图的最小生成树。既然是图,就假设包含n个顶点,m条边。prim算法是从顶点出发的,其算法时间复杂度与顶点数目有关系。 (注意:prim算法适合稠密图,其时间复杂度为O(n^2),其时间 ...
分类:
编程语言 时间:
2018-11-30 00:32:47
阅读次数:
193
含【最小生成树Prim】模板。 Prim复杂度为$O(n^2),适用于稠密图,特别是完全图的最小生成树的求解。 Desert King Time Limit: 3000MS Memory Limit: 65536K Total Submissions:31622 Accepted: 8670 Des ...
分类:
其他好文 时间:
2018-11-20 15:00:32
阅读次数:
230
传送门 如果没有挖井只是联通所有点就是最小生成树 但是有挖井,我们需要转换一下 把挖井操作看成 0 号点连一条边过去 然后还是最小生成树.. 因为是稠密图,所以用 prim 算法来求最小生成树 ...
分类:
其他好文 时间:
2018-10-26 10:37:09
阅读次数:
129
复习二分图又想起了这道题,裸的二分图匹配,直接匈牙利算法就可以了,mark一下这个比较好用的稠密图匈牙利算法模板 题目:题目链接 AC代码: ...
分类:
其他好文 时间:
2018-10-14 16:38:45
阅读次数:
178
今天学长对比了最小生成树最快速的求法不管是稠密图还是稀疏图,prim+邻接表+堆优化都能得到一个很不错的速度,所以参考学长的代码打出了下列代码,make_pair还不是很会,大体理解的意思是可以同时绑定两种元素(和struct差不多)但加入堆的时候以第一个元素来进行优先队列,建立的是大根堆由于每次要 ...
分类:
其他好文 时间:
2018-09-19 20:01:49
阅读次数:
189
今天复习了图的知识,稍作回顾整理。 描述一个图,无非一个点集V,一个边集E. 图的存储有邻接矩阵(适用于稠密图),邻接表(适用于稀疏图),十字链表(有向图),多重邻接表(无向图)。当我们说边<A,B>时,A是弧尾,B是弧头。 图的遍历可以用DFS{深度优先搜索}或者BFS{广度优先搜索}实现。这个时 ...
分类:
其他好文 时间:
2018-09-19 01:19:14
阅读次数:
160
以前一直只会克鲁斯卡尔,不过大部分最小生成树的题基本上用克鲁斯卡尔也能搞过去 不过对于稠密图甚至完全图来说Prim就非常高效了,尤其是我现在还记得Noip2017的宝藏是可以用Prim+退火水过去的 Prim算法之前学的时候也没怎么学会,一直就放下了,昨天复习迪杰斯特拉的时候想起来Prim和迪杰斯特 ...
分类:
其他好文 时间:
2018-09-05 11:38:31
阅读次数:
144
http://codeforces.com/problemset/problem/920/E 题意:求一个图的补图的连通分量个数以及每个连通分量里的点个数 如果这不是一个补图,BFS或者并查集可过,但是补图显然是一个稠密图,O(n2)的算法会T,但我们依然可以用BFS来直接跑,但是需要用到链表来进行 ...
分类:
其他好文 时间:
2018-09-03 02:40:06
阅读次数:
139
多么痛的领悟! 不要认为Prim不常见就用不到! 和Kruskal一样,Prim算法也是用来求MST的,也是体现了贪心的思想。 不同的是,Kruskal是针对边而言的,Prim是针对点而言的。Kruskal适用于稀疏图,Prim适用于稠密图,更值得一提的是,Prim可以不必保存每条边。 算法思想是, ...
分类:
编程语言 时间:
2018-09-02 23:53:01
阅读次数:
242