summaryrefslogtreecommitdiff
path: root/BJC-Utils2/src/main/java/bjc/utils/esodata/QueueStack.java
diff options
context:
space:
mode:
authorbculkin2442 <bjculkin@mix.wvu.edu>2017-03-11 05:22:08 -0500
committerbculkin2442 <bjculkin@mix.wvu.edu>2017-03-11 05:22:08 -0500
commit4631f2cec9d94a0b4869fe1fc5c3c036f42a8db0 (patch)
treeffaa8fe45ad2fd8dc23cdcd9d321a3b3ca40331a /BJC-Utils2/src/main/java/bjc/utils/esodata/QueueStack.java
parent21490abbcc03f9bbd467a53d09dd5ab69c081edc (diff)
Stack work
There are now multiple kinds of stacks, with Stack being abstract and SimpleStack being the basic implementation. QueueStack is a stack that's actually a queue. SpaghettiStack is a stack that has a parent it can access.
Diffstat (limited to 'BJC-Utils2/src/main/java/bjc/utils/esodata/QueueStack.java')
-rw-r--r--BJC-Utils2/src/main/java/bjc/utils/esodata/QueueStack.java50
1 files changed, 50 insertions, 0 deletions
diff --git a/BJC-Utils2/src/main/java/bjc/utils/esodata/QueueStack.java b/BJC-Utils2/src/main/java/bjc/utils/esodata/QueueStack.java
new file mode 100644
index 0000000..472e161
--- /dev/null
+++ b/BJC-Utils2/src/main/java/bjc/utils/esodata/QueueStack.java
@@ -0,0 +1,50 @@
+package bjc.utils.esodata;
+
+import java.util.ArrayList;
+import java.util.Deque;
+import java.util.List;
+import java.util.LinkedList;
+import java.util.function.Consumer;
+
+/**
+ * A FIFO implementation of a stack.
+ *
+ * @param T The datatype stored in the stack.
+ * @author Ben Culkin
+ */
+public class QueueStack<T> extends Stack<T> {
+ private Deque<T> backing;
+
+ /**
+ * Create a new empty stack queue.
+ *
+ */
+ public SimpleStack() {
+ backing = new LinkedList();
+ }
+
+ @Override
+ public void push(T elm) {
+ backing.add(elm);
+ }
+
+ @Override
+ public T pop() {
+ return backing.remove();
+ }
+
+ @Override
+ public T top() {
+ return backing.peek();
+ }
+
+ @Override
+ public int size() {
+ return backing.size();
+ }
+
+ @Override
+ public boolean empty() {
+ return backing.size() == 0;
+ }
+}