博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
[模板] 各种并查集
阅读量:6158 次
发布时间:2019-06-21

本文共 401 字,大约阅读时间需要 1 分钟。

按秩合并 && 撤销

int fa[nsz],dep[nsz];int stk[nsz][2],top=0;void init(){rep(i,1,n)fa[i]=i,dep[i]=1;}int find(int p){return p==fa[p]?p:find(fa[p]);}int iscon(int a,int b){return find(a)==find(b);}void merge(int a,int b){    a=find(a),b=find(b);    if(a==b)return;    if(dep[a]

路径压缩

大体同前, find函数略有不同.

不能撤销.

int find(int p){return p==fa[p]?p:p=find(fa[p]);}

转载于:https://www.cnblogs.com/ubospica/p/10645583.html

你可能感兴趣的文章
类中如何对list泛型做访问器??
查看>>
C++解析XML--使用CMarkup类解析XML
查看>>
P2P应用层组播
查看>>
Sharepoint学习笔记—修改SharePoint的Timeouts (Execution Timeout)
查看>>
CSS引入的方式有哪些? link和@import的区别?
查看>>
Redis 介绍2——常见基本类型
查看>>
asp.net开发mysql注意事项
查看>>
(转)Cortex-M3 (NXP LPC1788)之EEPROM存储器
查看>>
ubuntu set defult jdk
查看>>
[译]ECMAScript.next:TC39 2012年9月会议总结
查看>>
【Xcode】编辑与调试
查看>>
用tar和split将文件分包压缩
查看>>
[BTS] Could not find stored procedure 'mp_sap_check_tid'
查看>>
PLSQL DBMS_DDL.ALTER_COMPILE
查看>>
Activity生命周期
查看>>
高仿UC浏览器弹出菜单效果
查看>>
Ubuntu忘记密码,进不了系统的解决方法
查看>>
[原创]白盒测试技术思维导图
查看>>
<<Information Store and Management>> 读书笔记 之八
查看>>
Windows 8 开发之设置合约
查看>>