Project

General

Profile

Feature #4553 » pick_pop.diff

implementation and tests for Set#pick and Set#pop - adgar (Michael Edgar), 04/05/2011 08:10 AM

View differences:

lib/set.rb (working copy)
self
end
# Picks an arbitrary element from the set and returns it. Use +pop+ to
# pick and delete simultaneously.
def pick
@hash.first.first
end
# Picks an arbitrary element from the set and deletes it. Use +pick+ to
# pick without deletion.
def pop
key = pick
@hash.delete(key)
key
end
# Adds the given object to the set and returns self. Use +merge+ to
# add many elements at once.
def add(o)
......
}
end
def test_pick
set = Set[5,3,1]
assert_equal(true, set.include?(set.pick))
end
def test_pop
total = Set[9,1,8,2,7]
current = Set[9,1,8,2,7]
removed = Set[]
until current.empty?
removed << current.pop
assert_equal(total, current | removed)
assert_equal(true, (current & removed).empty?)
end
end
def test_add
set = Set[1,2,3]
    (1-1/1)