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

Each of these methods are public (NOT static) and I will test your completed Arr

ID: 3672077 • Letter: E

Question

Each of these methods are public (NOT static) and I will test your completed ArrayList.java with something like;

ArrayList<CalendarDate> list = new ArrayList<CalendarDate>();

A. list.reverse(); // page 948 Exercise #4, can work for any data type <E>
B. list.count(E); // Exercise #8, where E is the same data type as declared for the list.
C. list.mirror(); // Exercise #15, yes this is in Practice-IT, but this exam requires <E>
D.   list.switchPairs(); // Exercise #21. page 950 in 3rd edition.

Submit only one file: ArrayList.java

I will run my own tests using a static main() as in the past, do not have main() in above file.

Start of code testing:

    public static void main(String[] args) {
       ArrayList<CalendarDate> list = new ArrayList<CalendarDate>();
       CalendarDate today = new CalendarDate(2,26);
       list.reverse();
       list.count(today);
       list.mirror();
       list.switchPairs();
       System.out.println(list);
   }

----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------

// Class ArrayList<E> can be used to store a list of values of type E.

import java.util.Arrays;

import java.util.Iterator;

import java.util.NoSuchElementExceAption;

public class ArrayList<E> implements Iterable<E> {

    private E[] elementData; // list of values

    private int size;        // current number of elements in the list

    public static final int DEFAULT_CAPACITY = 100;

    // post: constructs an empty list of default capacity

    public ArrayList() {

        this(DEFAULT_CAPACITY);

    }

    // pre : capacity >= 0 (throws IllegalArgumentException if not)

    // post: constructs an empty list with the given capacity

    @SuppressWarnings("unchecked")

    public ArrayList(int capacity) {

        if (capacity < 0) {

            throw new IllegalArgumentException("capacity: " + capacity);

        }

        elementData = (E[]) new Object[capacity];

        size = 0;

    }

   

   

    // ADD YOUR METHODS FROM EXERCISES HERE

   

   

   

   

   

   

   

    // post: returns the current number of elements in the list

    public int size() {

        return size;

    }

    // pre : 0 <= index < size() (throws IndexOutOfBoundsException if not)

    // post: returns the value at the given index in the list

    public E get(int index) {

        checkIndex(index);

        return elementData[index];

    }

    // post: creates a comma-separated, bracketed version of the list

    public String toString() {

        if (size == 0) {

            return "[]";

        } else {

            String result = "[" + elementData[0];

            for (int i = 1; i < size; i++) {

                result += ", " + elementData[i];

            }

            result += "]";

            return result;

        }

    }

    // post : returns the position of the first occurrence of the given

    //        value (-1 if not found)

    public int indexOf(E value) {

        for (int i = 0; i < size; i++) {

            if (elementData[i].equals(value)) {

                return i;

            }

        }

        return -1;

    }

    // post: returns true if list is empty, false otherwise

    public boolean isEmpty() {

        return size == 0;

    }

    // post: returns true if the given value is contained in the list,

    //      false otherwise

    public boolean contains(E value) {

        return indexOf(value) >= 0;

    }

    // post: appends the given value to the end of the list

    public void add(E value) {

        ensureCapacity(size + 1);

        elementData[size] = value;

        size++;

    }

    // pre : 0 <= index <= size() (throws IndexOutOfBoundsException if not)

    // post: inserts the given value at the given index, shifting subsequent

    //       values right

    public void add(int index, E value) {

        if (index < 0 || index > size) {

            throw new IndexOutOfBoundsException("index: " + index);

        }

        ensureCapacity(size + 1);

        for (int i = size; i >= index + 1; i--) {

            elementData[i] = elementData[i - 1];

        }

        elementData[index] = value;

        size++;

    }

    // pre : 0 <= index < size() (throws IndexOutOfBoundsException if not)

    // 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];

        }

        elementData[size - 1] = null;

        size--;

    }

    // pre : 0 <= index < size() (throws IndexOutOfBoundsException if not)

    // post: replaces the value at the given index with the given value

    public void set(int index, E value) {

        checkIndex(index);

        elementData[index] = value;

    }

    // post: list is empty

    public void clear() {

        for (int i = 0; i < size; i++) {

            elementData[i] = null;

        }

        size = 0;

    }

    // post: appends all values in the given list to the end of this list

    public void addAll(ArrayList<E> other) {

        ensureCapacity(size + other.size);

        for (int i = 0; i < other.size; i++) {

            add(other.elementData[i]);

        }

    }

    // post: returns an iterator for this list

    public Iterator<E> iterator() {

        return new ArrayListIterator();

    }

    // 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;

            }

            elementData = Arrays.copyOf(elementData, newCapacity);

        }

    }

    // post: throws an IndexOutOfBoundsException if the given index is

    //       not a legal index of the current list

    private void checkIndex(int index) {

        if (index < 0 || index >= size) {

            throw new IndexOutOfBoundsException("index: " + index);

        }

    }

    private class ArrayListIterator implements Iterator<E> {

        private int position;           // current position within the list

        private boolean removeOK;       // whether it's okay to remove now

        // post: constructs an iterator for the given list

        public ArrayListIterator() {

            position = 0;

            removeOK = false;

        }

        // post: returns true if there are more elements left, false otherwise

        public boolean hasNext() {

            return position < size();

        }

        // pre : hasNext() (throws NoSuchElementException if not)

        // post: returns the next element in the iteration

        public E next() {

            if (!hasNext()) {

                throw new NoSuchElementException();

            }

            E result = elementData[position];

            position++;

            removeOK = true;

            return result;

        }

        // pre : next() has been called without a call on remove (throws

        //       IllegalStateException if not)

        // post: removes the last element returned by the iterator

        public void remove() {

            if (!removeOK) {

                throw new IllegalStateException();

            }

            ArrayList.this.remove(position - 1);

            position--;

            removeOK = false;

        }

    }

}

Explanation / Answer

ArrayList.java

// Class ArrayList<E> can be used to store a list of values of type E.
import java.util.Arrays;
import java.util.Iterator;
import java.util.NoSuchElementException;

public class ArrayList<E> implements Iterable<E> {
private E[] elementData; // list of values
private int size; // current number of elements in the list

public static final int DEFAULT_CAPACITY = 100;

// post: constructs an empty list of default capacity
public ArrayList() {
this(DEFAULT_CAPACITY);
}

// pre : capacity >= 0 (throws IllegalArgumentException if not)
// post: constructs an empty list with the given capacity
@SuppressWarnings("unchecked")
public ArrayList(int capacity) {
if (capacity < 0) {
throw new IllegalArgumentException("capacity: " + capacity);
}
elementData = (E[]) new Object[capacity];
size = 0;
}

// reverse the list
public void reverse() {
// if list contains one or zero elements do nothing
if (size == 0 || size == 1) {
return;
}

int i = 0, j = size - 1;
while (i < j) {
E tmp = elementData[i];
elementData[i] = elementData[j];
elementData[j] = tmp;
++i; --j;
}
}


// count occurance of given item in list
public int count(E item) {
int itemCount = 0;
for (int i = 0; i < size; ++i) {
if (elementData[i].equals(item)) {
itemCount++;
}
}
return itemCount;
}

// add reverse of the array to list
public void mirror() {
for (int i = size - 1; i >= 0; --i) {
add(elementData[i]);
}
}

// perform pairwise switching
public void switchPairs() {
int i = 0;
while (i + 1 < size) {
E tmp = elementData[i];
elementData[i] = elementData[i + 1];
elementData[i + 1] = tmp;
i += 2;
}
}

// post: returns the current number of elements in the list
public int size() {
return size;
}

// pre : 0 <= index < size() (throws IndexOutOfBoundsException if not)
// post: returns the value at the given index in the list
public E get(int index) {
checkIndex(index);
return elementData[index];
}

// post: creates a comma-separated, bracketed version of the list
public String toString() {
if (size == 0) {
return "[]";
} else {
String result = "[" + elementData[0];
for (int i = 1; i < size; i++) {
result += ", " + elementData[i];
}
result += "]";
return result;
}
}

// post : returns the position of the first occurrence of the given
// value (-1 if not found)
public int indexOf(E value) {
for (int i = 0; i < size; i++) {
if (elementData[i].equals(value)) {
return i;
}
}
return -1;
}

// post: returns true if list is empty, false otherwise
public boolean isEmpty() {
return size == 0;
}

// post: returns true if the given value is contained in the list,
// false otherwise
public boolean contains(E value) {
return indexOf(value) >= 0;
}

// post: appends the given value to the end of the list
public void add(E value) {
ensureCapacity(size + 1);
elementData[size] = value;
size++;
}

// pre : 0 <= index <= size() (throws IndexOutOfBoundsException if not)
// post: inserts the given value at the given index, shifting subsequent
// values right
public void add(int index, E value) {
if (index < 0 || index > size) {
throw new IndexOutOfBoundsException("index: " + index);
}
ensureCapacity(size + 1);
for (int i = size; i >= index + 1; i--) {
elementData[i] = elementData[i - 1];
}
elementData[index] = value;
size++;
}

// pre : 0 <= index < size() (throws IndexOutOfBoundsException if not)
// 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];
}
elementData[size - 1] = null;
size--;
}

// pre : 0 <= index < size() (throws IndexOutOfBoundsException if not)
// post: replaces the value at the given index with the given value
public void set(int index, E value) {
checkIndex(index);
elementData[index] = value;
}

// post: list is empty
public void clear() {
for (int i = 0; i < size; i++) {
elementData[i] = null;
}
size = 0;
}

// post: appends all values in the given list to the end of this list
public void addAll(ArrayList<E> other) {
ensureCapacity(size + other.size);
for (int i = 0; i < other.size; i++) {
add(other.elementData[i]);
}
}

// post: returns an iterator for this list
public Iterator<E> iterator() {
return new ArrayListIterator();
}

// 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;
}
elementData = Arrays.copyOf(elementData, newCapacity);
}
}

// post: throws an IndexOutOfBoundsException if the given index is
// not a legal index of the current list
private void checkIndex(int index) {
if (index < 0 || index >= size) {
throw new IndexOutOfBoundsException("index: " + index);
}
}

private class ArrayListIterator implements Iterator<E> {
private int position; // current position within the list
private boolean removeOK; // whether it's okay to remove now

// post: constructs an iterator for the given list
public ArrayListIterator() {
position = 0;
removeOK = false;
}

// post: returns true if there are more elements left, false otherwise
public boolean hasNext() {
return position < size();
}

// pre : hasNext() (throws NoSuchElementException if not)
// post: returns the next element in the iteration
public E next() {
if (!hasNext()) {
throw new NoSuchElementException();
}
E result = elementData[position];
position++;
removeOK = true;
return result;
}

// pre : next() has been called without a call on remove (throws
// IllegalStateException if not)
// post: removes the last element returned by the iterator
public void remove() {
if (!removeOK) {
throw new IllegalStateException();
}
ArrayList.this.remove(position - 1);
position--;
removeOK = false;
}
}
}

Main.java (testing)

public class Main {
   public static void main(String[] args) {
       ArrayList<Integer> myInts = new ArrayList<Integer>();
       for (int i = 0; i < 10; ++i) {
           myInts.add(i);
       }

       myInts.reverse();
       printList(myInts);

       System.out.println(myInts.count(2));

       myInts.mirror();
       printList(myInts);

       myInts.switchPairs();
       printList(myInts);
   }

   public static void printList(ArrayList<Integer> list) {
       for (int i = 0; i < list.size(); ++i) {
           System.out.print(list.get(i) + " ");
       }
       System.out.println();
   }
}

Hire Me For All Your Tutoring Needs
Integrity-first tutoring: clear explanations, guidance, and feedback.
Drop an Email at
drjack9650@gmail.com
Chat Now And Get Quote