Close
Register
Close Window

Masters of Engineering Bridge Course

Chapter 11 Lists and Iterators

Show Source |    | About   «  10.3. Unit 10 Lab 1 Placeholder   ::   Contents   ::   11.2. Unit 11 Lab 1 Placeholder  »

11.1. Lists

11.1.1. Overview & Objectives

Upon completion of this module, students will be able to:

  • Distinguish properties and use cases for a list from other ADT(stack, queues, bags)

  • Implement lists in java using an Array-Based or Linked-Chain approach

  • Consider various design approaches and corresponding efficiency

  • Trace and debug list implementations

11.1.2. List Introduction

11.1.2.1. [13:41] List Introduction Video

Video Slides 11.1.2.1-ListIntro.pdf

11.1.2.2. The List Interface

package list;

/**
 * An interface for the ADT list. Entries in a list have positions that begin
 * with 0
 *
 * @author Frank M. Carrano
 * @author Timothy M. Henry
 * @author maellis1
 * @version Aug 2020
 */
public interface ListInterface {
    /**
     * Adds a new entry to the end of this list. Entries currently in the list
     * are unaffected. The list's size is increased by 1.
     *
     * @param newEntry
     *            The object to be added as a new entry.
     */
    public void add(T newEntry);

    /**
     * Adds a new entry at a specified position within this list. Entries
     * originally at and above the specified position are at the next higher
     * position within the list. The list's size is increased by 1.
     *
     * @param newPosition
     *            An integer that specifies the desired position of the new
     *            entry.
     * @param newEntry
     *            The object to be added as a new entry.
     * @throws IndexOutOfBoundsException
     *             if either newPosition less than 0 or newPosition greater than
     *             getLength().
     */
    public void add(int newPosition, T newEntry);

    /**
     * Removes the entry at a given position from this list. Entries originally
     * at positions higher than the given position are at the next lower
     * position within the list, and the list's size is decreased by 1.
     *
     * @param givenPosition
     *            An integer that indicates the position of the entry to be
     *            removed.
     * @return A reference to the removed entry.
     * @throws IndexOutOfBoundsException
     *             if either givenPosition less than 0 or givenPosition greater
     *             than or equal to getLength().
     */
    public T remove(int givenPosition);

    /** Removes all entries from this list. */
    public void clear();

    /**
     * Replaces the entry at a given position in this list.
     *
     * @param givenPosition
     *            An integer that indicates the position of the entry to be
     *            replaced.
     * @param newEntry
     *            The object that will replace the entry at the position
     *            givenPosition.
     * @return The original entry that was replaced.
     * @throws IndexOutOfBoundsException
     *             if either givenPosition less than 0 or givenPosition greater
     *             than or equal to getLength().
     */
    public T replace(int givenPosition, T newEntry);

    /**
     * Retrieves the entry at a given position in this list.
     *
     * @param givenPosition
     *            An integer that indicates the position of the desired entry.
     * @return A reference to the indicated entry.
     * @throws IndexOutOfBoundsException
     *             if either givenPosition less than 0 or givenPosition greater
     *             than getLength().
     */
    public T getEntry(int givenPosition);

    /**
     * Retrieves all entries that are in this list in the order in which they
     * occur in the list.
     *
     * @return A newly allocated array of all the entries in the list. If the
     *         list is empty, the returned array is empty.
     */
    public Object[] toArray();

    /**
     * Sees whether this list contains a given entry.
     *
     * @param anEntry
     *            The object that is the desired entry.
     * @return True if the list contains anEntry, or false if not.
     */
    public boolean contains(T anEntry);

    /**
     * Gets the length of this list.
     *
     * @return The integer number of entries currently in the list.
     */
    public int getLength();

    /**
     * Sees whether this list is empty.
     *
     * @return True if the list is empty, or false if not.
     */
    public boolean isEmpty();
} // end ListInterface

11.1.3. Checkpoint 1

11.1.4. LinkedList Add Implementation

11.1.4.1. [10:21] LinkedList Add Implementation Video

Video Slides 11.1.3.1-LinkedListAdd.pdf

11.1.5. Checkpoint 2

11.1.6. Tracing Add with Debugger

11.1.6.1. [13:33] Tracing Add with Debugger Video

Video Slides 11.1.4.1-TraceAddDebugger.pdf

11.1.7. LinkedList Remove

11.1.7.1. [18:09] LinkedList Remove Video

Video Slides 11.1.5.1-LinkedListRemove.pdf

Try It Yourself

In Eclipse, use the Project > Download Assignment… menu command to download the lab project named “ex11.1.5.1-LinkedList”.

Refer to 01.02: Lab: LightBot for Beginners if you need to review the instructions for downloading Eclipse projects.

11.1.8. Checkpoint 3

11.1.9. Programming Practice: Lists 1

11.1.10. Considering and Array Implementation of a List

11.1.10.1. [10:19] LinkedList Details and Options Video

Video Slides 11.1.7.1-LinkedListMoreDetails.pdf

11.1.11. Checkpoint 4

11.1.12. Considering an Array Implementation of a List

11.1.12.1. [15:48] Array List Video

Video Slides 11.1.8.1-ArrayListImplementation.pdf

11.1.13. Programming Practice: Lists 2

   «  10.3. Unit 10 Lab 1 Placeholder   ::   Contents   ::   11.2. Unit 11 Lab 1 Placeholder  »

nsf
Close Window