Academic Integrity: tutoring, explanations, and feedback — we don’t complete graded work or submit on a student’s behalf.

I need help with this coding. I saw there are a lot of the same ones already pos

ID: 3920134 • Letter: I

Question

I need help with this coding. I saw there are a lot of the same ones already posted but I could not find any of them to work correctly so please do not copy and paste from other posts. Thank you!

import java.io.*;

import java.util.*;

/* Winter 2017, CS211, W.P. Iverson, instructor and author

* This is a start at testing code for Chapter 15 Assignment

* Other tests can and will happen....

*/

public class Post {

public static void main(String[] args) throws FileNotFoundException {

// required:

ArrayIntStack bag15 = new ArrayIntStack();

try {

bag15.pop();

} catch (EmptyStackException e) {

System.out.println(e);

}

bag15.push(42); bag15.push(24); bag15.push(-33);

// works without the generic Iterator from Oracle

ArrayIntStack.IntStackIterator handle = bag15.iterator();

while (handle.hasNext()) System.out.println(handle.next());

System.out.println(bag15.empty());

System.out.println(bag15.push(42));

System.out.println(bag15.pop());

System.out.println(bag15.peek());

// optional:

// if you implement Iterable<Iterator>

//for (Integer i : bag15) System.out.println(i);

}

}

THIS CODE IS ONLY HERE TO SHOW HOW IT'S SOMEWHAT SUPPOSED TO BE SIMILAR TO THIS.

import java.util.Arrays;
import java.util.Iterator;
import java.util.Collection;
import java.util.NoSuchElementException;
// BJP code fixed (by W.P. Iverson, 2017) to import only what's needed
// Class ArrayIntList can be used to store a list of integers.
//
// Most of this code from
// http://practiceit.cs.washington.edu/problems/shared/ArrayIntList.java
//
// Reges and Stepp provided inner class iterator (see end of file)
// and also provided (...) arguments as use in constructor
public class ArrayIntList implements Iterable<Integer> {
private int[] elementData; // list of integers
private int size = 0; // current number of elements in the list
  
public static final int DEFAULT_CAPACITY = 10;

// YOUR CODE GOES HERE
  

  
  
  
  
  
  
  
  
  
  
  
  
// post: constructs an empty list of default capacity
public ArrayIntList() {
this(DEFAULT_CAPACITY);
}
  
// pre : capacity >= 0
// post: constructs an empty list with the given capacity
private ArrayIntList(int capacity) {
if (capacity < 0) {
throw new IllegalArgumentException("Capacity must be at least 0: " + capacity);
}
elementData = new int[capacity];
}
  
// for creating test cases more easily, Reges provided ... arg
public ArrayIntList(int... elements) {
this(Math.max(DEFAULT_CAPACITY, elements.length * 2));
for (int n : elements) {
add(n);
}
}
  
// for creating test cases more easily (a dupe of the above constructor)
public static ArrayIntList withValues(int... elements) {
ArrayIntList list = new ArrayIntList(Math.max(DEFAULT_CAPACITY, elements.length * 2));
for (int n : elements) {
list.add(n);
}
return list;
}
  
// for creating test cases more easily
public ArrayIntList(int element, boolean notCapacity) {
this();
add(element);
}
  
// for creating test cases more easily
public ArrayIntList(Collection<Integer> elements) {
this(Math.max(DEFAULT_CAPACITY, elements.size() * 2));
for (int n : elements) {
add(n);
}
}
  
// copy constructor; for creating test cases more easily
public ArrayIntList(ArrayIntList list) {
this(Math.max(DEFAULT_CAPACITY, list.size() * 2));
addAll(list);
}
  
// pre : size() < capacity (elementData.length)
// post: appends the given value to the end of the list
public void add(int value) {
add(size, value);
}
  
// pre: size() < capacity (elementData.length) && 0 <= index <= size()
// post: inserts the given value at the given index, shifting subsequent
// values right
public void add(int index, int value) {
checkIndex(index, 0, size);
ensureCapacity(size + 1);
  
for (int i = size; i > index; i--) {
elementData[i] = elementData[i - 1];
}
elementData[index] = value;
size++;
}
  
// post: appends all values in the given list to the end of this list
public void addAll(ArrayIntList other) {
for (int i = 0; i < other.size; i++) {
add(other.elementData[i]);
}
}
  
// post: list is empty
public void clear() {
size = 0;
}
  
// post: returns true if the given value is contained in the list, false otherwise
public boolean contains(int value) {
return indexOf(value) != -1;
}
  
// post: ensures that the underlying array has the given capacity; if not,
// the size is doubled (or more if given capacity is even larger)
public void ensureCapacity(int capacity) {
if (capacity > elementData.length) {
int newCapacity = elementData.length * 2 + 1;
if (capacity > newCapacity) {
newCapacity = capacity;
}
int[] newList = new int[newCapacity];
for (int i = 0; i < size; i++) {
newList[i] = elementData[i];
}
elementData = newList;
}
}
  
// returns true if o is an ArrayIntList with the same size and elements as this one
public boolean equals(Object o) {
if (!(o instanceof ArrayIntList)) {
return false;
}

ArrayIntList other = (ArrayIntList) o;
if (this.size != other.size) {
return false;
}
  
for (int i = 0; i < size; i++) {
if (elementData[i] != other.elementData[i]) {
return false;
}
}
  
return true;
}
  
// pre : 0 <= index < size()
// post: returns the integer at the given index in the list
public int get(int index) {
checkIndex(index);
return elementData[index];
}
  
// post: returns capacity of this list's underlying array
public int getCapacity() {
return elementData.length;
}
  
// post : returns the position of the first occurence of the given
// value (-1 if not found)
public int indexOf(int value) {
for (int i = 0; i < size; i++) {
if (elementData[i] == value) {
return i;
}
}
return -1;
}
  
// post: returns true if list is empty, false otherwise
public boolean isEmpty() {
return size == 0;
}
  
// post: returns an iterator for this list
public Iterator<Integer> iterator() {
return new ArrayIntListIterator(this);
}
  
// pre : 0 <= index < size()
// post: removes value at the given index, shifting subsequent values left
public void remove(int index) {
checkIndex(index);
for (int i = index; i < size - 1; i++) {
elementData[i] = elementData[i + 1];
}
size--;
}
  
// post: removes all occurrences of the values in the given list from this list
public void removeAll(ArrayIntList other) {
int newSize = 0;
for (int i = 0; i < size; i++) {
if (!other.contains(elementData[i])) {
elementData[newSize] = elementData[i];
newSize++;
}
size = newSize;
}
}
  
// pre : 0 <= index < size()
// post: replaces the integer at the given index with the given value
public void set(int index, int value) {
checkIndex(index);
elementData[index] = value;
}
  
// post: returns the current number of elements in the list
public int size() {
return size;
}
  
// post: returns an array version of the contents of this list
public int[] toArray() {
return Arrays.copyOf(elementData, size);
}
  
// post: creates a comma-separated, bracketed version of the list
public String toString() {
String result = "[";
for (int i = 0; i < size; i++) {
if (i > 0) {
result += ", ";
}
if (i < elementData.length) {
result += elementData[i];
} else {
// student's code is bogus; OOB
result += "OOB!";
}
}
result += "]";
return result;
}
  
// helpers to make sure indexes do not fall out of bounds
private void checkIndex(int index) {
checkIndex(index, 0, size - 1);
}
  
private void checkIndex(int index, int min, int max) {
if (!(min <= index && index <= max)) {
throw new ArrayIndexOutOfBoundsException("Illegal index " + index +
"; must be between " + min + " and " + max + " "
+ "list : " + toString() + " (size=" + size + ") "
+ "array: " + Arrays.toString(elementData) + " (capacity=" + elementData.length + ")");
}
}
  
  
// Stuart Reges
// 4/4/05
//
// The ArrayIntListIterator class provides a set of utilities for iterating
// over an ArrayIntList and possibly removing values from the list.
  
public static class ArrayIntListIterator implements Iterator<Integer> {
private ArrayIntList list; // list to iterate over
private int position; // current position within the list
private boolean removeOK; // whether it's okay to remove now
  
// pre : list != null
// post: constructs an iterator for the given list
public ArrayIntListIterator(ArrayIntList list) {
this.list = list;
position = 0;
removeOK = false;
}
  
// post: returns true if there are more elements left, false otherwise
public boolean hasNext() {
return position < list.size();
}
  
// pre : hasNext()
// post: returns the next element in the iteration
public Integer next() {
if (!hasNext())
throw new NoSuchElementException();
int result = list.get(position);
position++;
removeOK = true;
return result;
}
  
// pre : next() has been called without a call on remove (i.e., at most one
// call per call on next)
// post: removes the last element returned by the iterator
public void remove() {
if (!removeOK)
throw new IllegalStateException();
list.remove(position - 1);
position--;
removeOK = false;
}
}   


}

Explanation / Answer

Here is the completed code for this problem. Comments are included, go through it, learn how things work and let me know if you have any doubts. Thanks

// ArrayIntStack.java

import java.util.Arrays;

import java.util.Iterator;

public class ArrayIntStack implements Iterable<Integer> {

      // array to store items

      private int[] stack;

      private int top; // index of top element

      private int DEFAULT_CAPACITY = 20;

      /**

      * default constructor

      */

      public ArrayIntStack() {

            /**

            * initializing stack

            */

            stack = new int[DEFAULT_CAPACITY];

            top = -1;

      }

      /**

      * copy constructor for assisting the IntStackIterator class

      *

      * @param other

      *            - other stack

      */

      public ArrayIntStack(ArrayIntStack other) {

            /**

            * making this a copy of other stack

            */

            stack = Arrays.copyOf(other.stack, other.stack.length);

            top = other.top;

      }

      /**

      * @return true if the stack is empty, else false

      */

      public boolean empty() {

            return top == -1;

      }

      /**

      * @return top element without removing.

      * @throws EmptyStackException

      *             if stack is empty

      */

      public int peek() throws EmptyStackException {

            if (empty()) {

                  throw new EmptyStackException("Stack is empty!");

            }

            return stack[top];

      }

      /**

      * @return top element and remove it from the stack.

      * @throws EmptyStackException

      *             if stack is empty

      */

      public int pop() throws EmptyStackException {

            if (empty()) {

                  throw new EmptyStackException("Stack is empty!");

            }

            int item = stack[top];

            top--;

            return item;

      }

      /**

      * pushes an item to the top of stack

      */

      public int push(int item) {

            if (top == stack.length - 1) {

                  // doubling capacity

                  doubleCapacity();

            }

            top++;

            stack[top] = item;

            return stack[top];

      }

      /**

      * private method to double the stack array size

      */

      private void doubleCapacity() {

            stack = Arrays.copyOf(stack, stack.length * 2);

      }

      @Override

      public Iterator<Integer> iterator() {

            /**

            * returning an instance of IntStackIterator, passing this stack as

            * argument

            */

            return new IntStackIterator(this);

      }

}

// EmptyStackException.java

public class EmptyStackException extends Exception {

      public EmptyStackException(String msg) {

            // passing error message to super class

            super(msg);

      }

}

// IntStackIterator.java

import java.util.Iterator;

public class IntStackIterator implements Iterator<Integer> {

      private ArrayIntStack stack; // stack

      /**

      * constructor to initialize the iterator

      *

      * @param stack

      *            - ArrayIntStack to be iterated

      */

      public IntStackIterator(ArrayIntStack stack) {

            // taking a copy of ArrayIntStack object, so that the changes wont be

            // reflected on the original

            this.stack = new ArrayIntStack(stack);

      }

      @Override

      public boolean hasNext() {

            return !stack.empty();

      }

      @Override

      public Integer next() {

            try {

                  return stack.pop();

            } catch (EmptyStackException e) {

                  e.printStackTrace();

            }

            return -1;

      }

      @Override

      public void remove() {

            // TODO Auto-generated method stub

      }

}

// Test.java

public class Test {

      public static void main(String[] args) {

            /**

            * creating a stack and testing the methods

            */

            ArrayIntStack stack = new ArrayIntStack();

            stack.push(100);

            stack.push(200);

            stack.push(300);

            stack.push(400);

            stack.push(500);

            IntStackIterator iterator = (IntStackIterator) stack.iterator();

            while (iterator.hasNext()) {

                  System.out.println(iterator.next());

            }

            /**

            * if everything works normally, the program will print the numbers in

            * reverse order

            */

      }

}

/*OUTPUT*/

500

400

300

200

100