不相交集类
等价关系:自反性,对称性,传递性
class DisjSets//不相交集的类架构 { public: explicit DisjSets(int numElements); int find(int x) const; int find(int x); void unionSets(int root1,int root2); void unionSets2(int root1,int root2); private: vector<int> s; }; DisjSets::DisjSets(int numElements) : s(numElements)//初始化 { for(int i=0 ; i < s.size() ; i++) s[i] = -1; } void DisjSets::unionSets(int root1,int root2) { s[root2] = root1; } void DisjSets::unionSets2(int root1,int root2) { if( s[root2] < s[root1]) s[root1] = root2; else { if(s[root1] == s[root2]) s[root1]--; s[root2] = root1; } } int DisjSets::find(int x) const { if(s[x] < 0) return x; else return find(s[x]); }
灵巧求并算法:按大小求并,或者按高度求并
路径压缩:唯一变化就是返回的是 find 返回的值(与按大小求并完全兼容)
int DisjSets::find(int x) { if(s[x] < 0) return x; else return s[x] = find(s[x]); }
应用:迷宫问题
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 周边上新:园子的第一款马克杯温暖上架
· Open-Sora 2.0 重磅开源!
· 分享 3 个 .NET 开源的文件压缩处理库,助力快速实现文件压缩解压功能!
· Ollama——大语言模型本地部署的极速利器
· DeepSeek如何颠覆传统软件测试?测试工程师会被淘汰吗?