summary refs log tree commit diff stats
path: root/tests/sets/tsets3.nim
blob: f599f8e7d6da94c8b7f88a9663bfaf2df3470812 (plain) (blame)
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
pre { line-height: 125%; }
td.linenos .normal { color: inherit; background-color: transparent; padding-left: 5px; padding-right: 5px; }
span.linenos { color: inherit; background-color: transparent; padding-left: 5px; padding-right: 5px; }
td.linenos .special { color: #000000; background-color: #ffffc0; padding-left: 5px; padding-right: 5px; }
span.linenos.special { color: #000000; background-color: #ffffc0; padding-left: 5px; padding-right: 5px; }
.highlight .hll { background-color: #ffffcc }
.highlight .c { color: #888888 } /* Comment */
.highlight .err { color: #a61717; background-color: #e3d2d2 } /* Error */
.highlight .k { color: #008800; font-weight: bold } /* Keyword */
.highlight .ch { color: #888888 } /* Comment.Hashbang */
.highlight .cm { color: #888888 } /* Comment.Multiline */
.highlight .cp { color: #cc0000; font-weight: bold } /* Comment.Preproc */
.highlight .cpf { color: #888888 } /* Comment.PreprocFile */
.highlight .c1 { color: #888888 } /* Comment.Single */
.highlight .cs { color: #cc0000; font-weight: bold; background-color: #fff0f0 } /* Comment.Special */
.highlight .gd { color: #000000; background-color: #ffdddd } /* Generic.Deleted */
.highlight .ge { font-style: italic } /* Generic.Emph */
.highlight .ges { font-weight: bold; font-style: italic } /* Generic.EmphStrong */
.highlight .gr { color: #aa0000 } /* Generic.Error */
.highlight .gh { color: #333333 } /* Generic.Heading */
.highlight .gi { color: #000000; background-color: #ddffdd } /* Generic.Inserted */
.highlight .go { color: #888888 } /* Generic.Output */
.highlight .gp { color: #555555 } /* Generic.Prompt */
.highlight .gs { font-weight: bold } /* Generic.Strong */
.highlight .gu { color: #666666 } /* Generic.Subheading */
.highlight .gt { color: #aa0000 } /* Generic.Traceback */
.highlight .kc { color: #008800; font-weight: bold } /* Keyword.Constant */
.highlight .kd { color: #008800; font-weight: bold } /* Keyword.Declaration */
.highlight .kn { color: #008800; font-weight: bold } /* Keyword.Namespace */
.highlight .kp { color: #008800 } /* Keyword.Pseudo */
.highlight .kr { color: #008800; font-weight: bold } /* Keyword.Reserved */
.highlight .kt { color: #888888; font-weight: bold } /* Keyword.Type */
.highlight .m { color: #0000DD; font-weight: bold } /* Literal.Number */
.highlight .s { color: #dd2200; background-colo
include sets

let
  s1: TSet[int] = toSet([1, 2, 4, 8, 16])
  s2: TSet[int] = toSet([1, 2, 3, 5, 8])
  s3: TSet[int] = toSet([3, 5, 7])

block union:
  let
    s1_s2 = union(s1, s2)
    s1_s3 = s1 + s3
    s2_s3 = s2 + s3

  assert s1_s2.len == 7
  assert s1_s3.len == 8
  assert s2_s3.len == 6

  for i in s1:
    assert i in s1_s2
    assert i in s1_s3
  for i in s2:
    assert i in s1_s2
    assert i in s2_s3
  for i in s3:
    assert i in s1_s3
    assert i in s2_s3

  assert((s1 + s1) == s1)
  assert((s2 + s1) == s1_s2)

block intersection:
  let
    s1_s2 = intersection(s1, s2)
    s1_s3 = intersection(s1, s3)
    s2_s3 = s2 * s3

  assert s1_s2.len == 3
  assert s1_s3.len == 0
  assert s2_s3.len == 2

  for i in s1_s2:
    assert i in s1
    assert i in s2
  for i in s1_s3:
    assert i in s1
    assert i in s3
  for i in s2_s3:
    assert i in s2
    assert i in s3

  assert((s2 * s2) == s2)
  assert((s3 * s2) == s2_s3)

block symmetricDifference:
  let
    s1_s2 = symmetricDifference(s1, s2)
    s1_s3 = s1 -+- s3
    s2_s3 = s2 -+- s3

  assert s1_s2.len == 4
  assert s1_s3.len == 8
  assert s2_s3.len == 4

  for i in s1:
    assert i in s1_s2 xor i in s2
    assert i in s1_s3 xor i in s3
  for i in s2:
    assert i in s1_s2 xor i in s1
    assert i in s2_s3 xor i in s3
  for i in s3:
    assert i in s1_s3 xor i in s1
    assert i in s2_s3 xor i in s2

  assert((s3 -+- s3) == initSet[int]())
  assert((s3 -+- s1) == s1_s3)

block difference:
  let
    s1_s2 = difference(s1, s2)
    s1_s3 = difference(s1, s3)
    s2_s3 = s2 - s3

  assert s1_s2.len == 2
  assert s1_s3.len == 5
  assert s2_s3.len == 3

  for i in s1:
    assert i in s1_s2 xor i in s2
    assert i in s1_s3 xor i in s3
  for i in s2:
    assert i in s2_s3 xor i in s3

  assert((s2 - s2) == initSet[int]())
  assert((s1 - s3 - s1) == s1 -+- s3)

block disjoint:
  assert(not disjoint(s1, s2))
  assert disjoint(s1, s3)
  assert(not disjoint(s2, s3))
  assert(not disjoint(s2, s2))