#include <list.h>
Public Member Functions | |
List () | |
List (const List< T > &) | |
~List () | |
void | add (unsigned, const T &) |
void | addAll (const List< T > &) |
void | addAll (unsigned, const List< T > &) |
void | addFirst (const T &) |
void | addLast (const T &) |
void | clear () |
bool | contains (const T &) const |
bool | empty () const |
int | indexOf (const T &) const |
T & | get (unsigned) const |
T & | getFirst () const |
T & | getLast () const |
ListIterator< T > | listIterator () |
ListIterator< T > | listIterator (unsigned) |
T | remove (unsigned) |
T | removeFirst () |
T | removeFirstOccurrence (const T &) |
T | removeLast () |
T | removeLastOccurrence (const T &) |
T | set (unsigned, const T &) |
unsigned | size () const |
T * | toArray () const |
const List< T > & | operator= (const List< T > &) |
void | printInternal (ostream &=cout) const |
Private Member Functions | |
void | add (Node< T > *, const T &) |
void | initialize () |
Node< T > * | getIthNode (unsigned) const |
T | remove (Node< T > *) |
Private Attributes | |
Node< T > * | frontPtr |
Node< T > * | backPtr |
unsigned | sz |
Friends | |
ostream & | operator<< (ostream &, const List< T > &) |
Implementation of a List ADT using a doubly-linked list.
Copy constructor. Indirectly throws bad_alloc if new fails to allocate memory.
bad_alloc | if memory cannot be allocated. |
void List< T >::add | ( | unsigned | index, |
const T & | object | ||
) |
Adds the specified object to this list at the specified position. Indirectly throws bad_alloc if new fails to allocate memory. Directly throws out_of_range if the index is out of range.
index | the position at which to insert the object |
object | the object to be inserted |
bad_alloc | if memory cannot be allocated |
out_of_range | if the index is out of range |
Adds the specified object to this list at the specified position. Indirectly throws bad_alloc if new fails to allocate memory.
current | the position at which to insert the object |
object | the object to be inserted |
bad_alloc | if memory cannot be allocated |
Adds all of objects in the specified list to the end of this list. Indirectly throws bad_alloc if new fails to allocate memory.
list | containing the objects to be added |
bad_alloc | if memory cannot be allocated |
Adds all of objects in the specified list to the specified position of this list. Indirectly throws bad_alloc if new fails to allocate memory. Directly throws out_of_range if the index is out of range.
index | the position at which to insert the object |
list | containing the objects to be added |
bad_alloc | if memory cannot be allocated |
out_of_range | if the index is out of range |
void List< T >::addFirst | ( | const T & | object | ) |
Adds the specified object to the front of the list. Indirectly throws bad_alloc if new fails to allocate memory.
object | the object to be added to the front of the list |
bad_alloc | if memory cannot be allocated |
void List< T >::addLast | ( | const T & | object | ) |
Adds the specified object to the end of the list. Indirectly throws bad_alloc if new fails to allocate memory.
object | the object to be added to the back of the list |
bad_alloc | if memory cannot be allocated |
void List< T >::clear | ( | ) |
Clears this list by removing all of its elements.
bool List< T >::contains | ( | const T & | object | ) | const |
Returns true if this list contains the specified object.
object | the specified object |
bool List< T >::empty | ( | ) | const |
Returns true if this list is empty; returns false otherwise.
T & List< T >::get | ( | unsigned | index | ) | const |
Returns a reference to the object at the specified position in this list. Directly throws out_of_range if the index is out of range.
index | the position of the object |
out_of_range | if the index is out of range |
T & List< T >::getFirst | ( | ) | const |
Returns a reference to the first object in this list. Directly throws NoSuchObject if no such object exists in this list.
NoSuchObject | if no such object exists in this list |
Returns a pointer to the node at the specified position. Directly throws out_of_range if the index is out of range.
index | the position of the object |
out_of_range | if the position is out of range |
T & List< T >::getLast | ( | ) | const |
Returns a reference to the last object in this list. Directly throws NoSuchObject if no such object exists in this list.
NoSuchObject | if no such object exists in this list |
int List< T >::indexOf | ( | const T & | object | ) | const |
Returns the position of the specified object in this list. Returns -1 if the object is not in this list.
object | the object to be found in the list |
|
private |
Sets the private data members of this list to their defaults values; that is, sets the points to null and size to zero.
ListIterator< T > List< T >::listIterator | ( | ) |
Returns a bidirectional iterator for this list.
ListIterator< T > List< T >::listIterator | ( | unsigned | index | ) |
Returns a bidirectional iterator for this list that starts at the specified position. Directly throws out_of_range if the index is out of range.
index | the starting position of the iterator |
out_of_range | if the index is out of range |
Returns a deep copy of the specified list. Indirectly throws bad_alloc if new fails to allocate memory.
list | the list to be copied. |
bad_alloc | if memory cannot be allocated. |
void List< T >::printInternal | ( | ostream & | out = cout | ) | const |
A utility method that prints the internal state of this list.
T List< T >::remove | ( | unsigned | index | ) |
Removes and returns the object at the specified position.
index | the position of the object |
out_of_range | if the index is out of range |
Removes and returns the object to which current points.
current | the position of the object |
T List< T >::removeFirst | ( | ) |
Removes and returns the first object in this list. Directly throws NoSuchObject if no such object exists in this list.
NoSuchObject | if no such object exists in this list |
T List< T >::removeFirstOccurrence | ( | const T & | object | ) |
Removes and returns the first occurrence of the object in this list. Directly throws NoSuchObject if no such object exists in this list.
object | the object in the list |
NoSuchObject | if no such object exists in this list |
T List< T >::removeLast | ( | ) |
Removes and returns the last object in this list. Directly throws NoSuchObject if no such object exists in this list.
NoSuchObject | if no such object exists in this list |
T List< T >::removeLastOccurrence | ( | const T & | object | ) |
Removes and returns the last occurrence of the object in this list. Directly throws NoSuchObject if no such object exists in this list.
object | the object in the list |
NoSuchObject | if no such object exists in this list |
T List< T >::set | ( | unsigned | index, |
const T & | object | ||
) |
Sets the object at the specified position to the specified object and returns the replaced object. Directly throws out_of_range if the index is out of range.
index | the position of the object |
object | the object |
out_of_range | if the index is out of range |
unsigned List< T >::size | ( | ) | const |
Returns the size (i.e., number of objects) of this list.
T * List< T >::toArray | ( | ) | const |
Returns an array containing the objects of this list. Indirectly throws bad_alloc if new fails to allocate memory.
bad_alloc | if memory cannot be allocated. |
|
friend |
Overloaded stream insertion operator that outputs the specified list to the output stream in the format [e1,e2,e3,...], where e1, e2, ... are the elements of the list.
out | the output stream |
list | the specified list |