mirror of
https://github.com/nim-lang/Nim.git
synced 2025-12-28 17:04:41 +00:00
sets minor improvement (#16087)
This commit is contained in:
@@ -321,7 +321,7 @@ proc missingOrExcl*[A](s: var HashSet[A], key: A): bool =
|
||||
exclImpl(s, key)
|
||||
|
||||
proc pop*[A](s: var HashSet[A]): A =
|
||||
## Remove and return an arbitrary element from the set `s`.
|
||||
## Removes and returns an arbitrary element from the set `s`.
|
||||
##
|
||||
## Raises KeyError if the set `s` is empty.
|
||||
##
|
||||
@@ -915,271 +915,3 @@ iterator pairs*[A](s: OrderedSet[A]): tuple[a: int, b: A] =
|
||||
|
||||
forAllOrderedPairs:
|
||||
yield (idx, s.data[h].key)
|
||||
|
||||
# -----------------------------------------------------------------------
|
||||
|
||||
|
||||
|
||||
when isMainModule and not defined(release):
|
||||
proc testModule() =
|
||||
## Internal micro test to validate docstrings and such.
|
||||
block lenTest:
|
||||
var values: HashSet[int]
|
||||
assert values.len == 0
|
||||
assert values.card == 0
|
||||
|
||||
block setIterator:
|
||||
type pair = tuple[a, b: int]
|
||||
var a, b = initHashSet[pair]()
|
||||
a.incl((2, 3))
|
||||
a.incl((3, 2))
|
||||
a.incl((2, 3))
|
||||
for x, y in a.items:
|
||||
b.incl((x - 2, y + 1))
|
||||
assert a.len == b.card
|
||||
assert a.len == 2
|
||||
#echo b
|
||||
|
||||
block setContains:
|
||||
var values = initHashSet[int]()
|
||||
assert(not values.contains(2))
|
||||
values.incl(2)
|
||||
assert values.contains(2)
|
||||
values.excl(2)
|
||||
assert(not values.contains(2))
|
||||
|
||||
values.incl(4)
|
||||
var others = toHashSet([6, 7])
|
||||
values.incl(others)
|
||||
assert values.len == 3
|
||||
|
||||
values.init
|
||||
assert values.containsOrIncl(2) == false
|
||||
assert values.containsOrIncl(2) == true
|
||||
var
|
||||
a = toHashSet([1, 2])
|
||||
b = toHashSet([1])
|
||||
b.incl(2)
|
||||
assert a == b
|
||||
|
||||
block exclusions:
|
||||
var s = toHashSet([2, 3, 6, 7])
|
||||
s.excl(2)
|
||||
s.excl(2)
|
||||
assert s.len == 3
|
||||
|
||||
var
|
||||
numbers = toHashSet([1, 2, 3, 4, 5])
|
||||
even = toHashSet([2, 4, 6, 8])
|
||||
numbers.excl(even)
|
||||
#echo numbers
|
||||
# --> {1, 3, 5}
|
||||
|
||||
block toSeqAndString:
|
||||
var a = toHashSet([2, 7, 5])
|
||||
var b = initHashSet[int](a.len)
|
||||
for x in [2, 7, 5]: b.incl(x)
|
||||
assert($a == $b)
|
||||
#echo a
|
||||
#echo toHashSet(["no", "esc'aping", "is \" provided"])
|
||||
|
||||
#block orderedToSeqAndString:
|
||||
# echo toOrderedSet([2, 4, 5])
|
||||
# echo toOrderedSet(["no", "esc'aping", "is \" provided"])
|
||||
|
||||
block setOperations:
|
||||
var
|
||||
a = toHashSet(["a", "b"])
|
||||
b = toHashSet(["b", "c"])
|
||||
c = union(a, b)
|
||||
assert c == toHashSet(["a", "b", "c"])
|
||||
var d = intersection(a, b)
|
||||
assert d == toHashSet(["b"])
|
||||
var e = difference(a, b)
|
||||
assert e == toHashSet(["a"])
|
||||
var f = symmetricDifference(a, b)
|
||||
assert f == toHashSet(["a", "c"])
|
||||
assert d < a and d < b
|
||||
assert((a < a) == false)
|
||||
assert d <= a and d <= b
|
||||
assert((a <= a))
|
||||
# Alias test.
|
||||
assert a + b == toHashSet(["a", "b", "c"])
|
||||
assert a * b == toHashSet(["b"])
|
||||
assert a - b == toHashSet(["a"])
|
||||
assert a -+- b == toHashSet(["a", "c"])
|
||||
assert disjoint(a, b) == false
|
||||
assert disjoint(a, b - a) == true
|
||||
|
||||
block mapSet:
|
||||
var a = toHashSet([1, 2, 3])
|
||||
var b = a.map(proc (x: int): string = $x)
|
||||
assert b == toHashSet(["1", "2", "3"])
|
||||
|
||||
block lenTest:
|
||||
var values: OrderedSet[int]
|
||||
assert values.len == 0
|
||||
assert values.card == 0
|
||||
|
||||
block setIterator:
|
||||
type pair = tuple[a, b: int]
|
||||
var a, b = initOrderedSet[pair]()
|
||||
a.incl((2, 3))
|
||||
a.incl((3, 2))
|
||||
a.incl((2, 3))
|
||||
for x, y in a.items:
|
||||
b.incl((x - 2, y + 1))
|
||||
assert a.len == b.card
|
||||
assert a.len == 2
|
||||
|
||||
block setPairsIterator:
|
||||
var s = toOrderedSet([1, 3, 5, 7])
|
||||
var items = newSeq[tuple[a: int, b: int]]()
|
||||
for idx, item in s: items.add((idx, item))
|
||||
assert items == @[(0, 1), (1, 3), (2, 5), (3, 7)]
|
||||
|
||||
block exclusions:
|
||||
var s = toOrderedSet([1, 2, 3, 6, 7, 4])
|
||||
|
||||
s.excl(3)
|
||||
s.excl(3)
|
||||
s.excl(1)
|
||||
s.excl(4)
|
||||
|
||||
var items = newSeq[int]()
|
||||
for item in s: items.add item
|
||||
assert items == @[2, 6, 7]
|
||||
|
||||
block: #9005
|
||||
var s = initOrderedSet[(int, int)]()
|
||||
for i in 0 .. 30: incl(s, (i, 0))
|
||||
for i in 0 .. 30: excl(s, (i, 0))
|
||||
doAssert s.len == 0
|
||||
|
||||
#block orderedSetIterator:
|
||||
# var a = initOrderedSet[int]()
|
||||
# for value in [9, 2, 1, 5, 1, 8, 4, 2]:
|
||||
# a.incl(value)
|
||||
# for value in a.items:
|
||||
# echo "Got ", value
|
||||
|
||||
block setContains:
|
||||
var values = initOrderedSet[int]()
|
||||
assert(not values.contains(2))
|
||||
values.incl(2)
|
||||
assert values.contains(2)
|
||||
|
||||
block toSeqAndString:
|
||||
var a = toOrderedSet([2, 4, 5])
|
||||
var b = initOrderedSet[int]()
|
||||
for x in [2, 4, 5]: b.incl(x)
|
||||
assert($a == $b)
|
||||
assert(a == b) # https://github.com/Araq/Nim/issues/1413
|
||||
|
||||
block initBlocks:
|
||||
var a: OrderedSet[int]
|
||||
a.init(4)
|
||||
a.incl(2)
|
||||
a.init
|
||||
assert a.len == 0
|
||||
a = initOrderedSet[int](4)
|
||||
a.incl(2)
|
||||
assert a.len == 1
|
||||
|
||||
var b: HashSet[int]
|
||||
b.init(4)
|
||||
b.incl(2)
|
||||
b.init
|
||||
assert b.len == 0
|
||||
b = initHashSet[int](4)
|
||||
b.incl(2)
|
||||
assert b.len == 1
|
||||
|
||||
block missingOrExcl:
|
||||
var s = toOrderedSet([2, 3, 6, 7])
|
||||
assert s.missingOrExcl(4) == true
|
||||
assert s.missingOrExcl(6) == false
|
||||
|
||||
block orderedSetEquality:
|
||||
type pair = tuple[a, b: int]
|
||||
|
||||
var aa = initOrderedSet[pair]()
|
||||
var bb = initOrderedSet[pair]()
|
||||
|
||||
var x = (a: 1, b: 2)
|
||||
var y = (a: 3, b: 4)
|
||||
|
||||
aa.incl(x)
|
||||
aa.incl(y)
|
||||
|
||||
bb.incl(x)
|
||||
bb.incl(y)
|
||||
assert aa == bb
|
||||
|
||||
block setsWithoutInit:
|
||||
var
|
||||
a: HashSet[int]
|
||||
b: HashSet[int]
|
||||
c: HashSet[int]
|
||||
d: HashSet[int]
|
||||
e: HashSet[int]
|
||||
|
||||
doAssert a.containsOrIncl(3) == false
|
||||
doAssert a.contains(3)
|
||||
doAssert a.len == 1
|
||||
doAssert a.containsOrIncl(3)
|
||||
a.incl(3)
|
||||
doAssert a.len == 1
|
||||
a.incl(6)
|
||||
doAssert a.len == 2
|
||||
|
||||
b.incl(5)
|
||||
doAssert b.len == 1
|
||||
b.excl(5)
|
||||
b.excl(c)
|
||||
doAssert b.missingOrExcl(5)
|
||||
doAssert b.disjoint(c)
|
||||
|
||||
d = b + c
|
||||
doAssert d.len == 0
|
||||
d = b * c
|
||||
doAssert d.len == 0
|
||||
d = b - c
|
||||
doAssert d.len == 0
|
||||
d = b -+- c
|
||||
doAssert d.len == 0
|
||||
|
||||
doAssert (d < e) == false
|
||||
doAssert d <= e
|
||||
doAssert d == e
|
||||
|
||||
block setsWithoutInit:
|
||||
var
|
||||
a: OrderedSet[int]
|
||||
b: OrderedSet[int]
|
||||
c: OrderedSet[int]
|
||||
d: HashSet[int]
|
||||
|
||||
|
||||
doAssert a.containsOrIncl(3) == false
|
||||
doAssert a.contains(3)
|
||||
doAssert a.len == 1
|
||||
doAssert a.containsOrIncl(3)
|
||||
a.incl(3)
|
||||
doAssert a.len == 1
|
||||
a.incl(6)
|
||||
doAssert a.len == 2
|
||||
|
||||
b.incl(5)
|
||||
doAssert b.len == 1
|
||||
doAssert b.missingOrExcl(5) == false
|
||||
doAssert b.missingOrExcl(5)
|
||||
|
||||
doAssert c.missingOrExcl(9)
|
||||
d.incl(c)
|
||||
doAssert d.len == 0
|
||||
|
||||
when not defined(testing):
|
||||
echo "Micro tests run successfully."
|
||||
|
||||
testModule()
|
||||
|
||||
@@ -119,3 +119,264 @@ block hashForOrderdSet:
|
||||
reversed = !$reversed
|
||||
doAssert hash(r) == reversed
|
||||
doAssert hash(s1) != reversed
|
||||
|
||||
|
||||
proc testModule() =
|
||||
## Internal micro test to validate docstrings and such.
|
||||
block lenTest:
|
||||
var values: HashSet[int]
|
||||
doAssert values.len == 0
|
||||
doAssert values.card == 0
|
||||
|
||||
block setIterator:
|
||||
type pair = tuple[a, b: int]
|
||||
var a, b = initHashSet[pair]()
|
||||
a.incl((2, 3))
|
||||
a.incl((3, 2))
|
||||
a.incl((2, 3))
|
||||
for x, y in a.items:
|
||||
b.incl((x - 2, y + 1))
|
||||
doAssert a.len == b.card
|
||||
doAssert a.len == 2
|
||||
#echo b
|
||||
|
||||
block setContains:
|
||||
var values = initHashSet[int]()
|
||||
doAssert(not values.contains(2))
|
||||
values.incl(2)
|
||||
doAssert values.contains(2)
|
||||
values.excl(2)
|
||||
doAssert(not values.contains(2))
|
||||
|
||||
values.incl(4)
|
||||
var others = toHashSet([6, 7])
|
||||
values.incl(others)
|
||||
doAssert values.len == 3
|
||||
|
||||
values.init
|
||||
doAssert values.containsOrIncl(2) == false
|
||||
doAssert values.containsOrIncl(2) == true
|
||||
var
|
||||
a = toHashSet([1, 2])
|
||||
b = toHashSet([1])
|
||||
b.incl(2)
|
||||
doAssert a == b
|
||||
|
||||
block exclusions:
|
||||
var s = toHashSet([2, 3, 6, 7])
|
||||
s.excl(2)
|
||||
s.excl(2)
|
||||
doAssert s.len == 3
|
||||
|
||||
var
|
||||
numbers = toHashSet([1, 2, 3, 4, 5])
|
||||
even = toHashSet([2, 4, 6, 8])
|
||||
numbers.excl(even)
|
||||
#echo numbers
|
||||
# --> {1, 3, 5}
|
||||
|
||||
block toSeqAndString:
|
||||
var a = toHashSet([2, 7, 5])
|
||||
var b = initHashSet[int](a.len)
|
||||
for x in [2, 7, 5]: b.incl(x)
|
||||
doAssert($a == $b)
|
||||
#echo a
|
||||
#echo toHashSet(["no", "esc'aping", "is \" provided"])
|
||||
|
||||
#block orderedToSeqAndString:
|
||||
# echo toOrderedSet([2, 4, 5])
|
||||
# echo toOrderedSet(["no", "esc'aping", "is \" provided"])
|
||||
|
||||
block setOperations:
|
||||
var
|
||||
a = toHashSet(["a", "b"])
|
||||
b = toHashSet(["b", "c"])
|
||||
c = union(a, b)
|
||||
doAssert c == toHashSet(["a", "b", "c"])
|
||||
var d = intersection(a, b)
|
||||
doAssert d == toHashSet(["b"])
|
||||
var e = difference(a, b)
|
||||
doAssert e == toHashSet(["a"])
|
||||
var f = symmetricDifference(a, b)
|
||||
doAssert f == toHashSet(["a", "c"])
|
||||
doAssert d < a and d < b
|
||||
doAssert((a < a) == false)
|
||||
doAssert d <= a and d <= b
|
||||
doAssert((a <= a))
|
||||
# Alias test.
|
||||
doAssert a + b == toHashSet(["a", "b", "c"])
|
||||
doAssert a * b == toHashSet(["b"])
|
||||
doAssert a - b == toHashSet(["a"])
|
||||
doAssert a -+- b == toHashSet(["a", "c"])
|
||||
doAssert disjoint(a, b) == false
|
||||
doAssert disjoint(a, b - a) == true
|
||||
|
||||
block mapSet:
|
||||
var a = toHashSet([1, 2, 3])
|
||||
var b = a.map(proc (x: int): string = $x)
|
||||
doAssert b == toHashSet(["1", "2", "3"])
|
||||
|
||||
block lenTest:
|
||||
var values: OrderedSet[int]
|
||||
doAssert values.len == 0
|
||||
doAssert values.card == 0
|
||||
|
||||
block setIterator:
|
||||
type pair = tuple[a, b: int]
|
||||
var a, b = initOrderedSet[pair]()
|
||||
a.incl((2, 3))
|
||||
a.incl((3, 2))
|
||||
a.incl((2, 3))
|
||||
for x, y in a.items:
|
||||
b.incl((x - 2, y + 1))
|
||||
doAssert a.len == b.card
|
||||
doAssert a.len == 2
|
||||
|
||||
block setPairsIterator:
|
||||
var s = toOrderedSet([1, 3, 5, 7])
|
||||
var items = newSeq[tuple[a: int, b: int]]()
|
||||
for idx, item in s: items.add((idx, item))
|
||||
doAssert items == @[(0, 1), (1, 3), (2, 5), (3, 7)]
|
||||
|
||||
block exclusions:
|
||||
var s = toOrderedSet([1, 2, 3, 6, 7, 4])
|
||||
|
||||
s.excl(3)
|
||||
s.excl(3)
|
||||
s.excl(1)
|
||||
s.excl(4)
|
||||
|
||||
var items = newSeq[int]()
|
||||
for item in s: items.add item
|
||||
doAssert items == @[2, 6, 7]
|
||||
|
||||
block: #9005
|
||||
var s = initOrderedSet[(int, int)]()
|
||||
for i in 0 .. 30: incl(s, (i, 0))
|
||||
for i in 0 .. 30: excl(s, (i, 0))
|
||||
doAssert s.len == 0
|
||||
|
||||
#block orderedSetIterator:
|
||||
# var a = initOrderedSet[int]()
|
||||
# for value in [9, 2, 1, 5, 1, 8, 4, 2]:
|
||||
# a.incl(value)
|
||||
# for value in a.items:
|
||||
# echo "Got ", value
|
||||
|
||||
block setContains:
|
||||
var values = initOrderedSet[int]()
|
||||
doAssert(not values.contains(2))
|
||||
values.incl(2)
|
||||
doAssert values.contains(2)
|
||||
|
||||
block toSeqAndString:
|
||||
var a = toOrderedSet([2, 4, 5])
|
||||
var b = initOrderedSet[int]()
|
||||
for x in [2, 4, 5]: b.incl(x)
|
||||
doAssert($a == $b)
|
||||
doAssert(a == b) # https://github.com/Araq/Nim/issues/1413
|
||||
|
||||
block initBlocks:
|
||||
var a: OrderedSet[int]
|
||||
a.init(4)
|
||||
a.incl(2)
|
||||
a.init
|
||||
doAssert a.len == 0
|
||||
a = initOrderedSet[int](4)
|
||||
a.incl(2)
|
||||
doAssert a.len == 1
|
||||
|
||||
var b: HashSet[int]
|
||||
b.init(4)
|
||||
b.incl(2)
|
||||
b.init
|
||||
doAssert b.len == 0
|
||||
b = initHashSet[int](4)
|
||||
b.incl(2)
|
||||
doAssert b.len == 1
|
||||
|
||||
block missingOrExcl:
|
||||
var s = toOrderedSet([2, 3, 6, 7])
|
||||
doAssert s.missingOrExcl(4) == true
|
||||
doAssert s.missingOrExcl(6) == false
|
||||
|
||||
block orderedSetEquality:
|
||||
type pair = tuple[a, b: int]
|
||||
|
||||
var aa = initOrderedSet[pair]()
|
||||
var bb = initOrderedSet[pair]()
|
||||
|
||||
var x = (a: 1, b: 2)
|
||||
var y = (a: 3, b: 4)
|
||||
|
||||
aa.incl(x)
|
||||
aa.incl(y)
|
||||
|
||||
bb.incl(x)
|
||||
bb.incl(y)
|
||||
doAssert aa == bb
|
||||
|
||||
block setsWithoutInit:
|
||||
var
|
||||
a: HashSet[int]
|
||||
b: HashSet[int]
|
||||
c: HashSet[int]
|
||||
d: HashSet[int]
|
||||
e: HashSet[int]
|
||||
|
||||
doAssert a.containsOrIncl(3) == false
|
||||
doAssert a.contains(3)
|
||||
doAssert a.len == 1
|
||||
doAssert a.containsOrIncl(3)
|
||||
a.incl(3)
|
||||
doAssert a.len == 1
|
||||
a.incl(6)
|
||||
doAssert a.len == 2
|
||||
|
||||
b.incl(5)
|
||||
doAssert b.len == 1
|
||||
b.excl(5)
|
||||
b.excl(c)
|
||||
doAssert b.missingOrExcl(5)
|
||||
doAssert b.disjoint(c)
|
||||
|
||||
d = b + c
|
||||
doAssert d.len == 0
|
||||
d = b * c
|
||||
doAssert d.len == 0
|
||||
d = b - c
|
||||
doAssert d.len == 0
|
||||
d = b -+- c
|
||||
doAssert d.len == 0
|
||||
|
||||
doAssert (d < e) == false
|
||||
doAssert d <= e
|
||||
doAssert d == e
|
||||
|
||||
block setsWithoutInit:
|
||||
var
|
||||
a: OrderedSet[int]
|
||||
b: OrderedSet[int]
|
||||
c: OrderedSet[int]
|
||||
d: HashSet[int]
|
||||
|
||||
|
||||
doAssert a.containsOrIncl(3) == false
|
||||
doAssert a.contains(3)
|
||||
doAssert a.len == 1
|
||||
doAssert a.containsOrIncl(3)
|
||||
a.incl(3)
|
||||
doAssert a.len == 1
|
||||
a.incl(6)
|
||||
doAssert a.len == 2
|
||||
|
||||
b.incl(5)
|
||||
doAssert b.len == 1
|
||||
doAssert b.missingOrExcl(5) == false
|
||||
doAssert b.missingOrExcl(5)
|
||||
|
||||
doAssert c.missingOrExcl(9)
|
||||
d.incl(c)
|
||||
doAssert d.len == 0
|
||||
|
||||
testModule()
|
||||
|
||||
Reference in New Issue
Block a user