package programmingexample3;
import java.util.ArrayList;
import java.util.Iterator;
/**
* A hamper implemented using an ArrayList.
*
* @author Matthew Perry
*
* @invariant for all c in counts, c.getCount() > 0
*
* @param
*/
public class ArrayListItemHamper
private ArrayList
/**
* Create a new empty hamper.
*/
public ArrayListItemHamper() {
this.counts = new ArrayList
}
private Count
for (Count
if (c.getElement().equals(o))
return c;
return null;
}
@Override
public void add(E e) {
add(e,1);
}
@Override
public void add(E e, int n) {
Count
if (c != null) {
c.incrementCount(n);
} else if (n > 0) {
counts.add(new Count
}
}
@Override
public void remove(E e) {
remove(e, 1);
}
@Override
public void remove(E e, int n) {
// TODO implement this
// get the count of the elements, if doesnt exist return doing nothing
Count
if (c == null) {
return;
}
// If there is more items than selected then remove that many items, set to 0
if(count(e) > n) {
c.decrementCount(n);
}
else {
counts.remove(c);
}
}
@Override
public int count(Object o) {
Count
if (c != null)
return c.getCount();
return 0;
}
@Override
public int size() {
// TODO implement this
int total = 0;
for (Count
total += c.getCount();
}
return total;
}
@Override
public Hamper
// TODO implement this
// create new hamper
Hamper
// Add both hampers to this new one
for (Count
combined.add(c.getElement(), c.getCount());
}
var hamperIter = hamper.iterator();
while(hamperIter.hasNext()) {
var c = hamperIter.next();
combined.add(c.getElement(), c.getCount());
}
return combined;
}
@Override
public Iterator
return counts.iterator();
}
/**
* For this method, hampers should be the same class to be equal (ignore the generic type component). For example, a CreativeHamper cannot be equal to a FruitHamper,
* And a FruitHamper cannot be equal to an ArrayListItemHamper
* However an ArrayListItemHamper
* HINT: use getclass() to compare objects.
*/
@Override
public boolean equals(Object o) {
// TODO implement this
// Check if both refer to the same object
if (this == o) {
return true;
}
// Check other is not null
if ( o == null) {
return false;
}
// Check hampers of same class, if not return false
if(!this.getClass().equals(o.getClass())) {
return false;
}
// Cast other to a hamper of same time
ArrayListItemHamper> other = (ArrayListItemHamper>) o;
// Check both hampers have same number of items
if (size() != other.size()){
return false;
}
// Check the number of each element matches between both hampers
var hamperIter = other.iterator();
while(hamperIter.hasNext()) {
var cOther = hamperIter.next();
// Check if the number of this element matches in the other
boolean matchFound = false;
for (Count
// If element are equal and count are equal, then a match is found
if(cThis.getElement().equals(cOther.getElement()) && cThis.getCount() == cOther.getCount()) {
matchFound = true;
}
}
// If a match wasnt found then not equal and return false
if (!matchFound) {
return false;
}
}
// If made it to here every check was passed so return true
return true;
}
/**
*
* @return price of the hamper – for ArrayListItemHamper, this should be the sum of the prices of items with each price multiplied by the number of times that item occurs
*/
@Override
public int getPrice() {
// TODO implement this
// Go through each count, grab its price and multiple by number
int total = 0;
for (Count
total += c.getElement().getPrice() * c.getCount();
}
return total;
}
@Override
public String toString(){
return counts.toString();
}
}