disjoint set

mail@pastecode.io avatar
unknown
swift
5 months ago
821 B
2
Indexable
final class UnionFind {
    private var root = [Int]()
    private var rank = [Int]()
    
    init(size: Int) {
        rank = [Int](repeating: 1, count: size)
        for i in 0..<size {
            root.append(i)
        }
    }
    
    func find(_ x: Int) -> Int {
        let rootX = root[x]
        if rootX == x {
            return rootX
        }
        root[x] = find(rootX)
        return root[x]
    }
    
    func union(x: Int, y: Int) {
        let rootX = find(x)
        let rootY = find(y)
        if rank[x] > rank[y] {
            root[rootY] = rootX
        } else if rank[y] > rank[x] {
            root[rootX] = rootY
        } else {
            root[rootY] = rootX
            rank[rootX] += 1
        }
    }
    
    func connected(x: Int, y: Int) -> Bool {
        find(x) == find(y)
    }
}
Leave a Comment