-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathinsert-delete-getrandom-o1.go
More file actions
61 lines (52 loc) · 1 KB
/
Copy pathinsert-delete-getrandom-o1.go
File metadata and controls
61 lines (52 loc) · 1 KB
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
package main
import (
"math/rand"
"time"
)
// source: https://leetcode.com/problems/insert-delete-getrandom-o1/
type RandomizedSet struct {
data map[int]bool
keys []int
}
func Constructor() RandomizedSet {
rand.Seed(time.Now().Unix())
return RandomizedSet{
data: make(map[int]bool),
keys: make([]int, 0),
}
}
func (rs *RandomizedSet) Insert(val int) bool {
if !rs.data[val] {
rs.data[val] = true
rs.keys = append(rs.keys, val)
return true
}
return false
}
func (rs *RandomizedSet) Remove(val int) bool {
if rs.data[val] {
delete(rs.data, val)
return true
}
return false
}
func (rs *RandomizedSet) GetRandom() int {
for len(rs.keys) > 0 {
i := rand.Intn(len(rs.keys))
if v := rs.keys[i]; rs.data[v] {
return v
}
rs.keys = append(rs.keys[:i], rs.keys[i+1:]...)
}
return -1
}
func main() {
rs := Constructor()
println(rs.Insert(1))
println(rs.Remove(2))
println(rs.Insert(2))
println(rs.GetRandom())
println(rs.Remove(1))
println(rs.Insert(2))
println(rs.GetRandom())
}