-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathGoodList.java
135 lines (112 loc) · 2.25 KB
/
GoodList.java
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
import java.util.LinkedList;
import java.util.ListIterator;
import java.util.NoSuchElementException;
import java.util.Iterator;
/**
* "Good" implementation of IndexedUnsortedList interface
* using Java API LinkedList class.
*
* @param <T> - type of elements held in this collection
* @author CS 221
*/
public class GoodList<T> implements IndexedUnsortedList<T> {
private LinkedList<T> list;
public GoodList() {
list = new LinkedList<T>();
}
@Override
public void addToFront(T element) {
list.addFirst(element);
}
@Override
public void addToRear(T element) {
list.addLast(element);
}
@Override
public void addAfter(T element, T target) {
int targetIdx = list.indexOf(target);
if (targetIdx < 0) {
throw new NoSuchElementException();
} else {
list.add(targetIdx+1, element);
}
}
@Override
public void add(int index, T element) {
list.add(index, element);
}
@Override
public void add(T element) {
list.add(element);
}
@Override
public T removeFirst() {
return list.removeFirst();
}
@Override
public T removeLast() {
return list.removeLast();
}
@Override
public T remove(T element) {
int idx = list.indexOf(element);
if (idx < 0) {
throw new NoSuchElementException();
}
T t = list.get(idx);
list.remove(t);
return t;
}
@Override
public T remove(int index) {
return list.remove(index);
}
@Override
public T first() {
return list.getFirst();
}
@Override
public T last() {
return list.getLast();
}
@Override
public boolean contains(T target) {
return list.contains(target);
}
@Override
public boolean isEmpty() {
return list.isEmpty();
}
@Override
public int size() {
return list.size();
}
@Override
public void set(int index, T element) {
list.set(index, element);
}
@Override
public T get(int index) {
return list.get(index);
}
@Override
public int indexOf(T element) {
return list.indexOf(element);
}
@Override
public Iterator<T> iterator() {
return list.iterator();
}
@Override
public ListIterator<T> listIterator() {
throw new UnsupportedOperationException();
}
@Override
public ListIterator<T> listIterator(int startingIndex) {
throw new UnsupportedOperationException();
}
@Override
public String toString() {
return list.toString();
}
}