forked from TheAlgorithms/Java
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathGeneralQueue.java
136 lines (114 loc) · 2.74 KB
/
GeneralQueue.java
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
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
package com.dataStructures;
import com.types.Queue;
import java.util.Iterator;
import java.util.LinkedList;
import java.util.NoSuchElementException;
/**
* linkedList based implementation of queue.
* This implementation is not thread safe and need exclusive thread safety measures from the client.
*
* @param <T>
*/
public class GeneralQueue<T> implements Queue<T> {
private LinkedList<T> queue;
private Iterator<T> itr;
/**
* Overloaded constructor to create queue of specific size
*/
public GeneralQueue() {
queue = new LinkedList<>();
}
@Override
public boolean add(T t) {
if (queue == null) {
throw new IllegalStateException();
}
if (t == null) {
throw new NullPointerException();
}
queue.add(t);
return true;
}
@Override
public boolean remove(T t) {
if (null == queue) {
throw new NullPointerException();
}
if (queue.isEmpty()) {
throw new NoSuchElementException();
}
queue.remove(t);
return true;
}
@Override
public boolean isEmpty() {
return null == queue || queue.size() == 0;
}
@Override
public Iterator<T> iterator() {
if (queue == null) {
return null;
}
itr = queue.iterator();
return itr;
}
@Override
public boolean offer(T t) {
if (null == queue) {
return false;
}
if (t == null) {
throw new NullPointerException();
}
queue.add(t);
return true;
}
@Override
public T poll() {
if (queue == null || queue.isEmpty()) {
return null;
}
return queue.pollFirst();
}
@Override
public T element() {
if (queue == null || queue.isEmpty()) {
throw new NoSuchElementException();
}
return queue.peekFirst();
}
@Override
public T peek() {
if (null == queue || queue.size() == 0) {
return null;
}
return queue.peekFirst();
}
@Override
public boolean hasNext() {
return itr.hasNext();
}
@Override
public T next() {
return itr.next();
}
@Override
public Object[] toArray() {
Object[] elements = {};
if (null == queue || queue.isEmpty()) {
return elements;
}
elements = new Object[queue.size()];
for (int i = 0; i < queue.size(); i++) {
elements[i] = queue.get(i);
}
return elements;
}
@Override
public int size() {
if (null == queue || queue.isEmpty()) {
return 0;
}
return queue.size();
}
}