@[simp]
@[simp]
@[simp]
@[simp]
theorem
Batteries.UnionFind.arr_push
{m : Batteries.UnionFind}
:
m.push.arr = m.arr.push { parent := m.arr.size, rank := 0 }
@[simp]
theorem
Batteries.UnionFind.parentD_push
{a : Nat}
{arr : Array Batteries.UFNode}
:
Batteries.UnionFind.parentD (arr.push { parent := arr.size, rank := 0 }) a = Batteries.UnionFind.parentD arr a
@[simp]
theorem
Batteries.UnionFind.parent_push
{a : Nat}
{m : Batteries.UnionFind}
:
m.push.parent a = m.parent a
@[simp]
theorem
Batteries.UnionFind.rankD_push
{a : Nat}
{arr : Array Batteries.UFNode}
:
Batteries.UnionFind.rankD (arr.push { parent := arr.size, rank := 0 }) a = Batteries.UnionFind.rankD arr a
@[simp]
@[simp]
@[simp]
theorem
Batteries.UnionFind.root_push
{x : Nat}
{self : Batteries.UnionFind}
:
self.push.rootD x = self.rootD x
@[simp]
theorem
Batteries.UnionFind.arr_link
{self : Batteries.UnionFind}
{x y : Fin self.size}
{yroot : self.parent ↑y = ↑y}
:
(self.link x y yroot).arr = Batteries.UnionFind.linkAux self.arr x y
theorem
Batteries.UnionFind.parentD_linkAux
{i : Nat}
{self : Array Batteries.UFNode}
{x y : Fin self.size}
:
Batteries.UnionFind.parentD (Batteries.UnionFind.linkAux self x y) i = if ↑x = ↑y then Batteries.UnionFind.parentD self i
else
if self[↑y].rank < self[↑x].rank then if ↑y = i then ↑x else Batteries.UnionFind.parentD self i
else if ↑x = i then ↑y else Batteries.UnionFind.parentD self i
theorem
Batteries.UnionFind.parent_link
{self : Batteries.UnionFind}
{x y : Fin self.size}
(yroot : self.parent ↑y = ↑y)
{i : Nat}
:
theorem
Batteries.UnionFind.root_link
{self : Batteries.UnionFind}
{x y : Fin self.size}
(xroot : self.parent ↑x = ↑x)
(yroot : self.parent ↑y = ↑y)
:
@[irreducible]
theorem
Batteries.UnionFind.root_link.go
{self : Batteries.UnionFind}
{x y : Fin self.size}
(xroot : self.parent ↑x = ↑x)
(yroot : self.parent ↑y = ↑y)
{m : Batteries.UnionFind}
(hm : ∀ (i : Nat), m.parent i = if ↑y = i then ↑x else self.parent i)
(i : Nat)
:
theorem
Batteries.UnionFind.Equiv.symm
{self : Batteries.UnionFind}
{a b : Nat}
:
self.Equiv a b → self.Equiv b a
theorem
Batteries.UnionFind.Equiv.trans
{self : Batteries.UnionFind}
{a b c : Nat}
:
self.Equiv a b → self.Equiv b c → self.Equiv a c
@[simp]
@[simp]
theorem
Batteries.UnionFind.equiv_push
{a b : Nat}
{self : Batteries.UnionFind}
:
self.push.Equiv a b ↔ self.Equiv a b
@[simp]
theorem
Batteries.UnionFind.equiv_rootD
{self : Batteries.UnionFind}
{a : Nat}
:
self.Equiv (self.rootD a) a
@[simp]
theorem
Batteries.UnionFind.equiv_rootD_l
{self : Batteries.UnionFind}
{a b : Nat}
:
self.Equiv (self.rootD a) b ↔ self.Equiv a b
@[simp]
theorem
Batteries.UnionFind.equiv_rootD_r
{self : Batteries.UnionFind}
{a b : Nat}
:
self.Equiv a (self.rootD b) ↔ self.Equiv a b
theorem
Batteries.UnionFind.equiv_find
{a b : Nat}
{self : Batteries.UnionFind}
{x : Fin self.size}
:
(self.find x).fst.Equiv a b ↔ self.Equiv a b
theorem
Batteries.UnionFind.equiv_union
{a b : Nat}
{self : Batteries.UnionFind}
{x y : Fin self.size}
: