当前位置: 首页 > news >正文

广州继续教育平台登录入口上海营销型网站seo

广州继续教育平台登录入口,上海营销型网站seo,网站变exe文件怎么做,问卷调查网站0. 引入 并查集是来解决等价问题的数据结构。 离散数学中的二元关系。 等价关系需满足自反性、对称性、传递性。 a ∈ S , a R a a R b & b R a a R b ∩ b R c > a R c a \in S, aRa \\ aRb \& bRa \\ aRb \cap bRc >aRc a∈S,aRaaRb&bRaaRb∩bRc>a…

0. 引入

并查集是来解决等价问题的数据结构。

离散数学中的二元关系。

等价关系需满足自反性、对称性、传递性。
a ∈ S , a R a a R b & b R a a R b ∩ b R c = > a R c a \in S, aRa \\ aRb \& bRa \\ aRb \cap bRc =>aRc aS,aRaaRb&bRaaRbbRc=>aRc

1. 需要实现的操作

给定n个数据,看能划分多少个等价类。

初始时即分为n个等价类,然后再一一合并。

所以需要实现的操作为:

  1. 合并两个等价类
  2. 查找元素属于哪个等价类

2. 实现

2.0 父节点
vector<int> pa;
2.1 查找
int Find(int k)
{return k == pa[k] ? k : Find(pa[k]);
}
2.2 合并
void Union(int a0, int a1)
{int p0 = Find(a0);int p1 = Find(a1);if ( p0 != p1 ) {pa[p0] = p1;}
}
2.3 路径压缩

对于查找来说如果简单的递归的话,最坏的情况便是全都在左子树。

(0,1) (0,2) (0,3) (0, 4) ... (0, n)

出现失去平衡
这样会导致单次查询如同一个链表一样达到O(n)

只需要改动一点点就可以完成路径压缩。

int Find(int k)
{
return k == pa[k] ? k : pa[k] = Find(pa[k]);
}
2.4 按节点数合并

可以令开一个数组,记录当前节点下的节点数。在合并的时候取小的节点合并到大的节点上去。

void Union(int a1, int a2)
{int p1 = Find(a1);int p2 = Find(a2);if ( p1 == p2)return;if (sz[p1] < sz[p2]) {pa[p1] = p2;sz[p2] += sz[p1];}else {pa[p2] = p1;sz[p1] += sz[p2];}     
}

3. 类封装

3.1 路径压缩
class UnionFind {public:explicit UnionFind(int sz):cnt(sz),pa(sz){iota(pa.begin(), pa.end(), 0);}int Find(int k ){return k == pa[k] ? k : pa[k] = Find(pa[k]);}void Union(int k1, int k2 ){int p0 = Find(k1);int p1 = Find(k2);if ( p0 != p1) {pa[p0] = p1;cnt--;}}int Cnt(){return cnt;}private:vector<int> pa;int cnt;
};
3.2 按节点数合并
public:
class UnionFind {public:explicit UnionFind(int _sz):cnt(_sz),pa(_sz),sz(_sz, 1){iota(pa.begin(), pa.end(), 0);}int Find(int k ){return k == pa[k] ? k : Find(pa[k]);}void Union(int k1, int k2 ){int p0 = Find(k1);int p1 = Find(k2);if (p0 == p1)return ;if (sz[p0] < sz[p1] ) {pa[p0] = p1;sz[p1] += sz[p0];}else {pa[p1] = p0;sz[p0] += sz[p1];}}int Cnt(){return cnt;}int Size(int idx){ return sz[idx]; }private:vector<int> pa,sz;int cnt;
};
4. 参考

lFoll题解
OIWIKI

http://www.yayakq.cn/news/973695/

相关文章:

  • 怎样建设淘宝客导购网站装潢设计工作室
  • 展示图片的网站模板如何进行网站维护
  • 网站优化报价硬件开发设计流程
  • 做企业网站要怎么设计方案忘记wordpress
  • 中国做网站的公司排名我的网址注册
  • 合肥专业网站制作python 网站开发实战
  • 网站开发需要做什么工作企业网站模板2016成套
  • 如果做游戏的技术用来做网站网站建设方向市场分析
  • 怎么做网站的产品分析网站营销软件
  • 户外家具技术支持东莞网站建设苏州精品网站建设
  • 音乐网站的设计写作网站都有哪些ppp
  • 重庆找工作的网站网站建设制作教程
  • 网站开发完后部署到网上网站域名响应时间
  • win7 iis建立网站用django怎么做网站
  • 西部网站管理助手陵水专业网站建设
  • 沧州市网站建设公司企业邮箱的个人邮箱
  • 投资网站排行wordpress折叠目录
  • 网络公司的手机网站俄语学习网站
  • 烟台html5网站建设泉州网页制作设计
  • 网站建设有哪些关键细节四川seo推广
  • 鞍山一般做一个网站需要多少钱u9u8网站建设
  • 织梦生成网站地图洛阳高新区做网站公司
  • 大连云建站模板网站编程赚钱
  • 电商食品网站建设简述网络推广的方法
  • 一个专门做海鲜的网站wordpress 编辑器调用
  • 青岛市黄岛区城市建设局网站西宁网站
  • joomla适合做什么网站深圳网站建设的公司
  • 做摄影网站的公司桥梁建设网站
  • 上海建设安检站网站社交网站 cms
  • 海南什么公司的网站建筑工程学院