forked from TheAlgorithms/Go
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathqueuelinkedlist.go
77 lines (62 loc) · 1.76 KB
/
queuelinkedlist.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
// Queue Linked-List
// description: based on `geeksforgeeks` description A Queue is a linear structure which follows a particular order in which the operations are performed.
// The order is First In First Out (FIFO).
// details:
// Queue Data Structure : https://www.geeksforgeeks.org/queue-data-structure/
// Queue (abstract data type) : https://en.wikipedia.org/wiki/Queue_(abstract_data_type)
// author [Milad](https://github.com/miraddo)
// see queuearray.go, queuelinkedlistwithlist.go, queue_test.go
package queue
// Node will be store the value and the next node as well
type Node struct {
Data interface{}
Next *Node
}
// Queue structure is tell us what our head is and what tail should be with length of the list
type Queue struct {
head *Node
tail *Node
length int
}
// enqueue it will be added new value into queue
func (ll *Queue) enqueue(n interface{}) {
var newNode Node // create new Node
newNode.Data = n // set the data
if ll.tail != nil {
ll.tail.Next = &newNode
}
ll.tail = &newNode
if ll.head == nil {
ll.head = &newNode
}
ll.length++
}
// dequeue it will be removed the first value into queue (First In First Out)
func (ll *Queue) dequeue() interface{} {
if ll.isEmpty() {
return -1 // if is empty return -1
}
data := ll.head.Data
ll.head = ll.head.Next
if ll.head == nil {
ll.tail = nil
}
ll.length--
return data
}
// isEmpty it will check our list is empty or not
func (ll *Queue) isEmpty() bool {
return ll.length == 0
}
// len is return the length of queue
func (ll *Queue) len() int {
return ll.length
}
// frontQueue it will return the front data
func (ll *Queue) frontQueue() interface{} {
return ll.head.Data
}
// backQueue it will return the back data
func (ll *Queue) backQueue() interface{} {
return ll.tail.Data
}