-
Notifications
You must be signed in to change notification settings - Fork 56
Expand file tree
/
Copy pathqueue.go
More file actions
87 lines (74 loc) · 1.2 KB
/
queue.go
File metadata and controls
87 lines (74 loc) · 1.2 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
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
package array
import (
"DSGO/utils"
)
type Queue[T any] interface {
utils.Queue[T]
IsFull() bool
}
func NewQueue[T any](size int) Queue[T] {
q := new(queue[T])
q.init(size)
return q
}
type queue[T any] struct {
r, w int
space []T
}
func (q *queue[T]) init(size int) {
if size < 7 {
size = 7
}
q.space = make([]T, size+1)
q.r, q.w = 0, 0
}
func (q *queue[T]) Clear() {
clear(q.space)
q.r, q.w = 0, 0
}
func (q *queue[T]) IsEmpty() bool {
return q.r == q.w
}
func (q *queue[T]) IsFull() bool {
return (q.w+1)%len(q.space) == q.r
}
func (q *queue[T]) Size() int {
size := q.w - q.r
if size < 0 {
size += len(q.space)
}
return size
}
func (q *queue[T]) Push(unit T) {
w := (q.w + 1) % len(q.space)
if w == q.r {
panic("full queue")
}
q.space[q.w] = unit
q.w = w
}
func (q *queue[T]) Pop() T {
if q.IsEmpty() {
panic("empty queue")
}
unit := q.space[q.r]
var zero T
q.space[q.r] = zero
q.r = (q.r + 1) % len(q.space)
return unit
}
func (q *queue[T]) Front() T {
if q.IsEmpty() {
panic("empty queue")
}
return q.space[q.r]
}
func (q *queue[T]) Back() T {
if q.IsEmpty() {
panic("empty queue")
}
if q.w == 0 {
return q.space[len(q.space)-1]
}
return q.space[q.w-1]
}