forked from EndlessCheng/codeforces-go
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathrand_test.go
98 lines (93 loc) · 1.75 KB
/
rand_test.go
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
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
package testutil
import (
"github.com/stretchr/testify/assert"
"sort"
"testing"
)
func TestRG_Permutation(t *testing.T) {
rg := NewRandGenerator()
min, max := 3, 7
n := max - min + 1
p := rg.UniqueSlice(n, min, max)
assert.Len(t, p, n)
sort.Ints(p)
for i, v := range p {
assert.Equal(t, min+i, v)
}
}
func TestRG_TreeEdges(t *testing.T) {
rg := NewRandGenerator()
n, st := 10, 1
edges := rg.TreeEdges(n, st)
g := make([][]int, n)
for _, e := range edges {
v, w := e[0]-st, e[1]-st
assert.True(t, v < w)
g[v] = append(g[v], w)
g[w] = append(g[w], v)
}
cc := 0
var f func(v, fa int)
f = func(v, fa int) {
cc++
for _, w := range g[v] {
if w != fa {
f(w, v)
}
}
}
f(0, -1)
assert.Equal(t, n, cc)
}
func TestRG_TreeWeightedEdges(t *testing.T) {
rg := NewRandGenerator()
n, st := 10, 1
mi, mx := 0, 1
edges := rg.TreeWeightedEdges(n, st, mi, mx)
g := make([][]int, n)
for _, e := range edges {
v, w, wt := e[0]-st, e[1]-st, e[2]
assert.True(t, v < w)
assert.True(t, mi <= wt && wt <= mx)
g[v] = append(g[v], w)
g[w] = append(g[w], v)
}
cc := 0
var f func(v, fa int)
f = func(v, fa int) {
cc++
for _, w := range g[v] {
if w != fa {
f(w, v)
}
}
}
f(0, -1)
assert.Equal(t, n, cc)
}
func TestRG_GraphEdges(t *testing.T) {
rg := NewRandGenerator()
n := 10
m := n * (n - 1) / 2 // complete graph
st := 1
edges := rg.GraphEdges(n, m, st, false)
// check edges form a complete graph
g := make([][]bool, n)
for i := range g {
g[i] = make([]bool, n)
}
for _, e := range edges {
v, w := e[0]-st, e[1]-st
assert.True(t, v < w)
g[v][w] = true
g[w][v] = true
}
for i, row := range g {
assert.False(t, row[i])
for j, has := range row {
if j != i {
assert.True(t, has)
}
}
}
}