不相交集类

简介:

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

复制代码
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月前
|
算法 C++
平面中判断线段与矩形是否相交
平面中判断线段与矩形是否相交
84 0
|
5月前
|
算法 C++ Windows
空间射线与三角形相交算法的两种实现
空间射线与三角形相交算法的两种实现
59 0
|
5月前
|
算法 C++
空间直线与球面相交算法
空间直线与球面相交算法
52 0
|
8月前
|
人工智能 BI
最大不相交区间
最大不相交区间
|
8月前
|
C++
相交链表(C++)
相交链表(C++)
51 0
判断线段是否相交
判断线段是否相交
99 0
160_相交链表
160_相交链表
111 0