forked from Hithomelabs/Princeton1
		
	Adding ArrayStack Implementation
This commit is contained in:
		
							parent
							
								
									9298520865
								
							
						
					
					
						commit
						a1c1b2a0f4
					
				| @ -0,0 +1,19 @@ | |||||||
|  | package com.hithomelabs.clients; | ||||||
|  | 
 | ||||||
|  | import com.hithomelabs.princeton1.module4.ArrayStack; | ||||||
|  | import com.hithomelabs.princeton1.module4.Stack; | ||||||
|  | 
 | ||||||
|  | public class ArrayStackClient { | ||||||
|  |     public static void main(String[] args) { | ||||||
|  |         Stack<Integer> stack = new ArrayStack<Integer>(); | ||||||
|  |         for(int i = 0; i < 21; i++){ | ||||||
|  |             stack.push(i); | ||||||
|  |         } | ||||||
|  |         // Using object s, as stack is generic but every java Object has implementation of toString() | ||||||
|  |         for (Object s : stack) | ||||||
|  |             System.out.println(s); | ||||||
|  |         while(!stack.isEmpty()){ | ||||||
|  |             System.out.println(stack.pop()); | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  | } | ||||||
| @ -4,7 +4,7 @@ package com.hithomelabs.clients; | |||||||
| import com.hithomelabs.princeton1.module4.LinkedStack; | import com.hithomelabs.princeton1.module4.LinkedStack; | ||||||
| import com.hithomelabs.princeton1.module4.Stack; | import com.hithomelabs.princeton1.module4.Stack; | ||||||
| 
 | 
 | ||||||
| public class Main { | public class LinkedArrayClient { | ||||||
|     public static void main(String[] args) { |     public static void main(String[] args) { | ||||||
|         Stack<String> stack = new LinkedStack<String>(); |         Stack<String> stack = new LinkedStack<String>(); | ||||||
|         stack.push("hello"); |         stack.push("hello"); | ||||||
| @ -0,0 +1,96 @@ | |||||||
|  | package com.hithomelabs.princeton1.module4; | ||||||
|  | import java.util.Iterator; | ||||||
|  | 
 | ||||||
|  | // Concrete implementation of stack using arrays | ||||||
|  | // Creating a generic stack of type E | ||||||
|  | public class ArrayStack<E> extends Stack<E> { | ||||||
|  | 
 | ||||||
|  |     // Capacity and size are two variables, capacity determines total capacity of array, capacity defaults at 10 | ||||||
|  |     // Everytime size == capacity, capacity = 2 * capacity | ||||||
|  |     private static final int DEFAULT_CAPACITY = 10; | ||||||
|  |     private int capacity; | ||||||
|  |     private int size; | ||||||
|  |     private E[] arr; | ||||||
|  | 
 | ||||||
|  |     public ArrayStack(int capacity){ | ||||||
|  |         this.capacity = capacity; | ||||||
|  |         this.arr = (E[]) new Object[this.capacity]; | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     // Constructor chaining, default constructor will call parametrised constructor with default initial capacity 10 | ||||||
|  |     public ArrayStack(){ | ||||||
|  |         this(DEFAULT_CAPACITY); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     @Override | ||||||
|  |     public boolean isEmpty() { | ||||||
|  |         return this.size == 0; | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     private void changeCapacity(int newCapacity){ | ||||||
|  |         E[] resizedArr = (E[]) new Object[newCapacity]; | ||||||
|  |         for (int i = 0; i < this.size; i++) | ||||||
|  |             resizedArr[i] = this.arr[i]; | ||||||
|  |         this.arr = resizedArr; | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     private void incrementSize(){ | ||||||
|  |         if (this.size == this.capacity){ | ||||||
|  |             this.capacity = 2 * this.capacity; | ||||||
|  |             changeCapacity(this.capacity); | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     // Push always happens at the end of the stack | ||||||
|  |     // Say the size of the stack is 1, new element gets inserted  at 1 | ||||||
|  |     @Override | ||||||
|  |     public void push(E element) { | ||||||
|  |         // Lazy approach, we assume size to always be lesser than capacity | ||||||
|  |         this.incrementSize(); | ||||||
|  |         this.arr[this.size++] = element; | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     @Override | ||||||
|  |     public E pop() { | ||||||
|  |         if (isEmpty()) | ||||||
|  |             return null; | ||||||
|  |         else{ | ||||||
|  |             E e = this.arr[--this.size]; | ||||||
|  |             this.arr[this.size] = null; | ||||||
|  |             this.checkResize(); | ||||||
|  |             return e; | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     private void checkResize() { | ||||||
|  |         if (this.size < this.capacity / 4 && this.capacity > 10){ | ||||||
|  |             this.capacity = this.capacity / 2; | ||||||
|  |             changeCapacity(this.capacity); | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     @Override | ||||||
|  |     public int size() { | ||||||
|  |         return this.size; | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     @Override | ||||||
|  |     public Iterator<E> iterator() { | ||||||
|  |         return new Iterator<E>() { | ||||||
|  | 
 | ||||||
|  |             int current = 0; | ||||||
|  | 
 | ||||||
|  |             @Override | ||||||
|  |             public boolean hasNext() { | ||||||
|  |                 return current != size; | ||||||
|  |             } | ||||||
|  | 
 | ||||||
|  |             @Override | ||||||
|  |             public E next() { | ||||||
|  |                 E element = arr[current]; | ||||||
|  |                 current = current + 1; | ||||||
|  |                 return element; | ||||||
|  |             } | ||||||
|  |         }; | ||||||
|  |     } | ||||||
|  | } | ||||||
		Loading…
	
		Reference in New Issue
	
	Block a user