summaryrefslogtreecommitdiff
path: root/spec/quick_union_spec.rb
blob: 362d2f250ce85c1ad8591a29cfd78a4cec645de4 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
require "spec_helper"

describe QuickUnion do
  subject { QuickUnion.new(10) }

  it "is not connected" do
    expect(subject.connected?(0, 1)).to be_false
  end

  it "is connected" do
    subject.union(4, 3)
    subject.connected?(4, 3).should be_true
    subject.union(3, 8)
    subject.connected?(3, 8).should be_true
    subject.union(6, 5)
    subject.connected?(6, 5).should be_true

    subject.union(9, 4)
    subject.connected?(9, 4).should be_true

    subject.union(2, 1)
    subject.connected?(8, 9).should be_true
    subject.connected?(5, 4).should be_false
    subject.union(5, 0)
    subject.connected?(5, 0).should be_true
    subject.union(7, 2)
    subject.connected?(7, 2).should be_true
    subject.union(6, 1)
    subject.connected?(6, 1).should be_true
    subject.union(7, 3)
    subject.connected?(7, 3).should be_true
  end
end