不相交集类

简介:

等价关系:自反性,对称性,传递性

复制代码
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]);
}
复制代码

应用:迷宫问题

本文转自博客园xingoo的博客,原文链接:不相交集类,如需转载请自行联系原博主。
相关文章
|
5月前
leetcode-1035:不相交的线
leetcode-1035:不相交的线
31 0
|
5月前
|
人工智能 BI
最大不相交区间
最大不相交区间
|
5月前
|
C++
相交链表(C++)
相交链表(C++)
38 0
|
11月前
|
存储
160.相交链表(LeetCode)
160.相交链表(LeetCode)
判断两个链表是否相交,相交的话返回相交的节点
1.判断是否相交 找到两个链表的最后一个节点,看是否相同,相同的话就相交,反之. 2.找两个链表长度的差值 为什么要找两个链表的差值呢? 为了判断哪个长,以便让长的链表先走差值,方便找相交处 3.找相交处 长的走后,再便利长的和短的一起走,以找到相交节点
34 0
|
C++
LeetCode 160.相交链表
LeetCode 160.相交链表
49 0
判断线段是否相交
判断线段是否相交
82 0
leetcode 1035 不相交的线
leetcode 1035 不相交的线
68 0
leetcode 1035 不相交的线
|
算法 Java
相交链表 (LeetCode 160)
相交链表 (LeetCode 160)
112 0