From 4631f2cec9d94a0b4869fe1fc5c3c036f42a8db0 Mon Sep 17 00:00:00 2001 From: bculkin2442 Date: Sat, 11 Mar 2017 05:22:08 -0500 Subject: 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. --- .../main/java/bjc/utils/esodata/SimpleStack.java | 50 ++++++++++++++++++++++ 1 file changed, 50 insertions(+) create mode 100644 BJC-Utils2/src/main/java/bjc/utils/esodata/SimpleStack.java (limited to 'BJC-Utils2/src/main/java/bjc/utils/esodata/SimpleStack.java') diff --git a/BJC-Utils2/src/main/java/bjc/utils/esodata/SimpleStack.java b/BJC-Utils2/src/main/java/bjc/utils/esodata/SimpleStack.java new file mode 100644 index 0000000..67f228f --- /dev/null +++ b/BJC-Utils2/src/main/java/bjc/utils/esodata/SimpleStack.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; + +/** + * Simple implementation of a stack. + * + * @param T The datatype stored in the stack. + * @author Ben Culkin + */ +public class SimpleStack extends Stack { + private Deque backing; + + /** + * Create a new empty stack. + * + */ + public SimpleStack() { + backing = new LinkedList(); + } + + @Override + public void push(T elm) { + backing.push(elm); + } + + @Override + public T pop() { + return backing.pop(); + } + + @Override + public T top() { + return backing.peek(); + } + + @Override + public int size() { + return backing.size(); + } + + @Override + public boolean empty() { + return backing.size() == 0; + } +} -- cgit v1.2.3