structure
Interface Stack<ELTTYPE>

All Superinterfaces:
java.lang.Iterable<ELTTYPE>, Linear<ELTTYPE>, Structure<ELTTYPE>
All Known Implementing Classes:
AbstractStack, StackArray, StackList, StackVector

public interface Stack<ELTTYPE>
extends Linear<ELTTYPE>

An interface describing a Last-In, First-Out structure. Stacks are typically used to store the state of a recursively solved problem. The structure package provides several implementations of the Stack interface, each of which has its particular strengths and weaknesses.

Example usage:

To reverse a string using a stack, we would use the following:

 public static void main(String[] arguments)
 {
     if(arguments.length > 0){
           Stack reverseStack = new StackList();
           String s = arguments[0];
            
           for(int i=0; i < s.length(); i++){
               reverseStack.push(new Character(s.charAt(i)));
           }

           while(!reverseStack.empty()){
               System.out.print(reverseStack.pop());
           }

           System.out.println();
     }
 }
 


Method Summary
 void add(ELTTYPE item)
          Add an element from the top of the stack.
 boolean empty()
          Returns true iff the stack is empty.
 ELTTYPE get()
          Fetch a reference to the top element of the stack.
 ELTTYPE getFirst()
          Fetch a reference to the top element of the stack.
 ELTTYPE peek()
          Fetch a reference to the top element of the stack.
 ELTTYPE pop()
          Remove an element from the top of the stack.
 void push(ELTTYPE item)
          Add an element to top of stack.
 ELTTYPE remove()
          Remove an element from the top of the stack.
 int size()
          Returns the number of elements in the stack.
 
Methods inherited from interface structure.Structure
clear, contains, elements, isEmpty, iterator, remove, values
 

Method Detail

add

void add(ELTTYPE item)
Add an element from the top of the stack.

Specified by:
add in interface Linear<ELTTYPE>
Specified by:
add in interface Structure<ELTTYPE>
Parameters:
item - The element to be added to the stack top.
See Also:
push(ELTTYPE)
Post:
item is added to stack will be popped next if no intervening add

push

void push(ELTTYPE item)
Add an element to top of stack.

Parameters:
item - The value to be added to the top of the stack.
Post:
item is added to stack will be popped next if no intervening push

remove

ELTTYPE remove()
Remove an element from the top of the stack.

Specified by:
remove in interface Linear<ELTTYPE>
Returns:
The item removed from the top of the stack.
See Also:
pop()
Pre:
stack is not empty
Post:
most recently added item is removed and returned

pop

ELTTYPE pop()
Remove an element from the top of the stack.

Returns:
A reference to the removed element.
Pre:
stack is not empty
Post:
most recently pushed item is removed and returned

get

ELTTYPE get()
Fetch a reference to the top element of the stack.

Specified by:
get in interface Linear<ELTTYPE>
Returns:
A reference to the top element of the stack.
Pre:
stack is not empty
Post:
top value (next to be popped) is returned

getFirst

ELTTYPE getFirst()
Fetch a reference to the top element of the stack.

Returns:
A reference to the top element of the stack.
Pre:
stack is not empty
Post:
top value (next to be popped) is returned

peek

ELTTYPE peek()
Fetch a reference to the top element of the stack.

Returns:
A reference to the top element of the stack.
Pre:
stack is not empty
Post:
top value (next to be popped) is returned

empty

boolean empty()
Returns true iff the stack is empty. Provided for compatibility with java.util.Vector.empty.

Specified by:
empty in interface Linear<ELTTYPE>
Returns:
True iff the stack is empty.
Post:
returns true if and only if the stack is empty

size

int size()
Returns the number of elements in the stack.

Specified by:
size in interface Linear<ELTTYPE>
Specified by:
size in interface Structure<ELTTYPE>
Returns:
number of elements in stack.
Post:
returns the number of elements in the stack