Lists Briana B. Morrison Adapted from Alan Eugenio & William J. Collins.

Slides:



Advertisements
Similar presentations
Números.
Advertisements


Chapter 22 Implementing lists: linked implementations.
EuroCondens SGB E.
The basics for simulations
Connecticut Mastery Test (CMT) and the Connecticut Academic Achievement Test (CAPT) Spring 2013 Presented to the Guilford Board of Education September.
COMP171 Fall 2005 Lists.
Chapter 4 Linked Lists. © 2005 Pearson Addison-Wesley. All rights reserved4-2 Preliminaries Options for implementing an ADT List –Array has a fixed size.
DATA STRUCTURES AND ALGORITHMS Prepared by İnanç TAHRALI
Linked Lists.
1111 Abstract Data Types Cpt S 223. School of EECS, WSU.
DATA STRUCTURES USING C++ Chapter 5
Main Index Contents 11 Main Index Contents Shifting blocks of elements… Shifting blocks of elements… Model of a list object… Model of a list object… Sample.
Lists: An internal look
Chapter 3 – Lists A list is just what the name implies, a finite, ordered sequence of items. Order indicates each item has a position. A list of size 0.
Copyright © 2007 Pearson Education, Inc. Publishing as Pearson Addison-Wesley. Ver Chapter 4: Linked Lists Data Abstraction & Problem Solving with.
Alan YorinksLecture 7 1 • Tonight we will look at:: • List ADT • Unsorted List • Sequential Search • Selection Sort • Sorted List • Binary Search.
Data Structures Intro/Linked List Review CIS 237 – Data Structures.
Chapter6 LISTS AND STRINGS. Outline 1. List Specifications 2. List Implementations (a) Class Templates (b) Contiguous (c) Simply Linked (d) Simply Linked.
CSE Lecture 12 – Linked Lists …
Bowls – A Sport for Life 69 Metropolitan Bowling Clubs read Jack Hi 140 Country Bowling Clubs read Jack Hi Hundreds of Community Members across the State.
Before Between After.
2.10% more children born Die 0.2 years sooner Spend 95.53% less money on health care No class divide 60.84% less electricity 84.40% less oil.
Linked Lists CENG 213 Data Structures.
Static Equilibrium; Elasticity and Fracture
Chapter 5.
úkol = A 77 B 72 C 67 D = A 77 B 72 C 67 D 79.
Chapter 17 Linked List Saurav Karmakar Spring 2007.
M180: Data Structures & Algorithms in Java
LINKED QUEUES P LINKED QUEUE OBJECT Introduction Introduction again, the problem with the previous example of queues is that we are working.
Week 5 - Associative Containers: sets and maps. 2 2 Main Index Main Index Content s Content s Container Types Sequence Containers Adapter Containers Associative.
Main Index Contents 11 Main Index Contents Container Types Container Types Sequence Containers Sequence Containers Associative Containers Associative Containers.
Main Index Contents 11 Main Index Contents Container Types Container Types Sequence Containers Sequence Containers Associative Containers Associative Containers.
1 Data Structures Data Structures Topic #2. 2 Today’s Agenda Data Abstraction –Given what we talked about last time, we need to step through an example.
Chapter 4 Linked Lists. © 2005 Pearson Addison-Wesley. All rights reserved4-2 Preliminaries Options for implementing an ADT List –Array has a fixed size.
Doubly Linked Lists CS 308 – Data Structures. Node data info: the user's data next, back: the address of the next and previous node in the list.back.next.info.
Chapter 4 Linked Lists. © 2005 Pearson Addison-Wesley. All rights reserved4-2 Preliminaries Options for implementing an ADT List –Array has a fixed size.
2 Preliminaries Options for implementing an ADT List Array has a fixed size Data must be shifted during insertions and deletions Linked list is able to.
Copyright © 2007 Pearson Education, Inc. Publishing as Pearson Addison-Wesley. Ver Chapter 4: Linked Lists Data Abstraction & Problem Solving with.
Containers Overview and Class Vector
1 Chapter 16-1 Linked Structures Dale/Weems. 2 Chapter 16 Topics l Meaning of a Linked List l Meaning of a Dynamic Linked List l Traversal, Insertion.
Introduction to STL and the vector container class CS342 Data Structures Based on Ford & Topp.
Main Index Contents 11 Main Index Contents Week 3 – The Vector Container.
Lab 7 Queue ADT. OVERVIEW The queue is one example of a constrained linear data structure. The elements in a queue are ordered from least recently added.
1 Chapter 16 Linked Structures Dale/Weems/Headington.
Nyhoff, ADTs, Data Structures and Problem Solving with C++, Second Edition, © 2005 Pearson Education, Inc. All rights reserved Stacks.
Prof. amr Goneid, AUC1 CSCE 110 PROGRAMMING FUNDAMENTALS WITH C++ Prof. Amr Goneid AUC Part 16. Linked Lists.
1 Linked-list, stack and queue. 2 Outline Abstract Data Type (ADT)‏ Linked list Stack Queue.
1 Data Structures CSCI 132, Spring 2014 Lecture 20 Linked Lists.
A Doubly Linked List prevnextdata There’s the need to access a list in reverse order header dnode.
1 Data Organization Example 1: Heap storage management –Keep track of free chunks of memory Example 2: A simple text editor –Maintain a sequence of lines.
1 C++ Plus Data Structures Nell Dale Chapter 5 Linked Structures Modified from the slides by Sylvia Sorkin, Community College of Baltimore County - Essex.
Chapter 6 LISTS AND STRINGS 1. List Definition 2. List Implementations (a) Class Templates (b) Contiguous (c) Simply Linked (d) Doubly Linked 3. Linked.
Prof. amr Goneid, AUC1 CSCE 110 PROGRAMMING FUNDAMENTALS WITH C++ Prof. Amr Goneid AUC Part 15. Dictionaries (1): A Key Table Class.
1 Chapter 15-1 Pointers, Dynamic Data, and Reference Types Dale/Weems.
1 Midterm 1 on Friday February 12 Closed book, closed notes No computer can be used 50 minutes 4 questions Write a function Write program fragment Explain.
1 Circular, Doubly-Linked Lists Node Composition List Class Pushing and Popping Values Insert and Erase at Arbitrary Locations List Implementation.
Introduction to Data Structure, Fall 2006 Slide- 1 California State University, Fresno Introduction to Data Structure Chapter 4 Ming Li Department of Computer.
Main Index Contents 11 Main Index Contents Sets Defined by a key along with other data Sets Defined by a key along with other data Key-Value Data Key-Value.
CS505 Data Structures and Algorithms
Chapter 4 Linked Lists.
A Doubly Linked List There’s the need to access a list in reverse order prev next data dnode header 1.
Chapter 4 Linked Lists
Array Lists Chapter 6 Section 6.1 to 6.3
Chapter 16-2 Linked Structures
Chapter 4 Linked Lists.
Doubly Linked List Implementation
Chapter 4 Linked Lists.
Doubly Linked List Implementation
The List Container and Iterators
Presentation transcript:

Lists Briana B. Morrison Adapted from Alan Eugenio & William J. Collins

Lists 2 Topics Review from Lists Implementing a linked list Doubly linked Dummy header node In an array Function Implementation Dynamic memory management

Lists 3 Abstract Model of a List Object

Lists 4

5 Model of a list object with links to next and previous element

Lists 6

7 The List ADT The list API documents the member function prototype as well as pre- and postconditions.

Lists 8 CLASS list Constructors list(); Create an empty list. This is the default constructor. list(int n, const T&value = T()); Create a list with n elements, each having a specified value. If the value argument is omitted, the elements are filled with the default value for type T. Type T must have a default constructor, and the default value of type T is specified by the notation T(). list(T *first, T *last); Initialize the list, using the address range [first, last).

Lists 9 The List Constructors provides three constructors to declare a list object.

Lists 10 CLASS list Operations T& back(); Return the value of the item at the rear of the list. Precondition: The list must contain at least one element. bool empty() const; Return true if the list is empty, false otherwise. T& front(); Return the value of the item at the front of the list. Precondition: The list must contain at least one element.

Lists 11 Using Front, Back and Empty int arr[5] = {9, 2, 7, 3, 12}; list lst(arr,arr+5); cout << lst.back( ); lst.back( ) = 99; cout << lst.front( ); lst.front( ) = 46; If (lst.empty( )) cout << Empty);

Lists 12 CLASS list Operations void push_back(const T& value); Add a value at the rear of the list. Postcondition: The list has a new element at the rear, and its size increases by 1. void pop_back(); Remove the item at the rear of the list. Precondition:The list is not empty. Postcondition:The list has a new element at the rear or is empty.

Lists 13 CLASS list Operations void push_front(const T& value); Add a value at the front of the list. Postcondition:The list has a new element at the front, and its size increases by 1. void pop_front(); Remove the item at the front of the list. Precondition:The list is not empty. Postcondition:The list has a new element at the front or is empty. int size() const; Return the number of elements in the list.

Lists 14 Using Push, Pop, and Size int arr[5] = {9, 2, 7, 3, 12}; list lst(arr,arr+5); lst.pop_back( ); lst.push_back(99); lst.pop_front( ); lst.push_front(11); cout << lst.size( );

Lists 15

Lists 16

Lists 17 CLASS list Operations iterator begin(); Returns an iterator that references the first position (front) of the list. If the list is empty, the iterator value end() is returned. const_iterator begin(); Returns a const_iterator that points to the first position (front) of a constant list. If the list is empty, the const_iterator value end() is returned.

Lists 18 CLASS list Operations iterator end(); Returns an iterator that signifies a location immediately out of the range of actual elements. A program must not dereference the value of end() with the * operator. const_iterator end(); Returns a const_iterator that signifies a location immediately out of the range of actual elements in a constant list. A program must not dereference the value of end() with the * operator.

Lists 19 Using Iterators To declare an iterator: list ::iterator listIter; list ::iterator iter; Using an iterator: list intList; listIter = intList.begin();//initialize listIter = intList.end();//past end of list

Lists 20 CLASS list Operations void erase(iterator pos); Erase the element pointed to by pos. Precondition:The list is not empty. Postcondition:The list has one fewer element. void erase(iterator first, iterator last); Erase all list elements within the iterator range [first, last]. Precondition:The list is not empty. Postcondition:The size of the list decreases by the number of elements in the range.

Lists 21 CLASS list Operations iterator insert(iterator pos, const T& value); Insert value before pos, and return an iterator pointing to the position of the new value in the list. The operation does not affect any existing iterators. Postcondition:The list has a new element.

Lists 22 Using Insert and Erase int arr[5] = {9, 2, 7, 3, 12}; list lst(arr,arr+5); list ::iterator listIter; listIter = lst.end( ); lst.insert(listIter, 14); listIter = lst.begin( ); listIter = lst.insert(listIter, 55); lst.erase(listIter);

Lists 23 CLASS list::iterator Operations * :Accesses the value of the item currently pointed to by the iterator.*iter; ++ :Moves the iterator to the next item in the list.iter++; -- :Moves the iterator to the previous item in the list.iter--; == :Takes two iterators as operands and returns true when they both point at the same item in the list. iter1 == iter2 != :Returns true when the two iterators do not point at the same item in the list. iter1 != iter2

Lists 24 Using Insert and Erase int arr[5] = {9, 2, 7, 3, 12}; list lst(arr,arr+5); list ::iterator listIter; listIter = lst.begin( ); listIter++; cout << *listIter; lst.insert(listIter, 44); listIter--; lst.erase(listIter);

Lists 25 Note about Iterators List iterators move through the list in a circular fashion. When an iterator is at end(), the operation++ move the iterator to the first list element, at location begin(); Similarly, when an iterator is at begin(), the operation -- moves the iterator to end();

Lists 26 iterator versus const_iterator Each standard library container (e.g. the list) provides both an iterator and a const_iterator The operations on them are the same, except When a const_iterator is dereferenced ( operator* ), the value of the item referenced cannot be changed.

Lists 27 Constant Iterators STL has a second type of iterator, constant iterator. Much like regular iterator except you cannot apply dereference (*) to a constant iterator on the left side of an assignment statement. Cannot be used with list insert() and erase() Can use ++ and -- to move through list. Rule: use constant iterator to access and scan a constant list. list ::const_iterator iter;

Lists 28 Iterator Hierarchy

Lists 29 Iterator Functions

Lists 30

Lists 31

Lists 32 Inserting an element into a list list intList (arr, arr+arrSize); list ::iterator iter, newElt; iter = intList.begin(); iter++; newElt = intlist.insert ( iter, 4);

Lists 33 Removing an element from a list list intList (arr, arr+arrSize); list ::iterator iter; iter = intList.begin(); iter++; intlist.erase (iter);

Lists 34 Ordered lists Position the iterator curr at the front of the list. Insert 50 in the list: curr = intList.begin(); intList.insert (curr, 50);

Lists 35 insertOrder() //insert item into the ordered list template <typename T. void insertOrder (list & orderedList, const T& item) { // curr starts at first list element, stop marks end list ::iterator curr = orderedList.begin(), stop = orderList.end(); // find the insertion point while ((curr != stop) && (*curr < item)) curr++; // do the insertion using insert() orderedList.insert (curr, item); }

Lists 36

Lists 37

Lists 38 Users Guide for choosing a list or vector If the application entails a lot of accessing and/or modifying items at widely varying positions, a vector will be much faster than a list. If a large part of the application consists of iterating through a container and making insertions and/or deletions during the iterations, a list will be much faster than a vector.

Lists 39

Lists 40

Lists 41

Lists 42 Splicing two lists destList 1516 sourceIter sourceList pos 5 destList (After insert of 15) 1516 sourceIter sourceList pos 5 destList (After insert of 16) sourceList pos 5 destList.splice(pos, sourceList);

Lists 43

Lists 44

Lists 45

Lists 46 apple banana candy donut egg

Lists 47 Linked List Basics Node Composition Inserting at Front Deleting at Front Inserting in Middle Deleting from Middle

Lists 48 Node Composition An individual Node is composed of two parts, a Data field containing the data stored by the node, and a Pointer field that marks the address of the next Node in the list.

Lists 49 A List Node A node contains: A data item One or more links A link is a pointer to a list node The node class is usually defined inside another class: It is a hidden inner class The details of a node should be kept private

Lists 50 List Nodes for Singly-Linked Lists

Lists 51 Inserting at the Front of a Linked List

Lists 52 Deleting From the Front of a Linked List

Lists 53 Removing a Target Node

Lists 54 Doubly Linked Lists Structure Inserting Circular doubly linked

Lists 55 Doubly-Linked Lists Limitations of a singly-linked list include: Can insert only after a referenced node Removing node requires pointer to previous node Can traverse list only in the forward direction We can remove these limitations: Add a pointer in each node to the previous node: doubly-linked list

Lists 56 Designing a New Linked List Structure

Lists 57 Doubly-Linked Lists, The Diagrams

Lists 58 Inserting a Node at a Position

Lists 59 Deleting a Node at a Position

Lists 60 Circular Doubly Linked Lists A Watch Band provides a good Real Life analogue for this Data Structure

Lists 61 Circular Lists Circular doubly-linked list: Link last node to the first node, and Link first node to the last Advantages: Can easily keep going past ends Can visit all elements from any starting point Can never fall off the end of a list Disadvantage: code must avoid infinite loop! Can also build singly-linked circular lists: Traverse in forward direction only

Lists 62 Circular Doubly Linked Lists Implemented on a Computer it might look something like this.

Lists 63 Implementing a Circular List

Lists 64 Updating a Doubly Linked List

Lists 65 struct versus class A struct is the same as a class. Except that the default visibility for a struct is public. Generally struct s are used to define classes that only contain public data fields. Constructors may be provided. Other member functions (operators) are usually not defined for struct s.

66 // Type DECLARATIONS struct NodeType { char info; NodeType* prev; NodeType* next; } typedef NodeType* NodePtr; // Variable DECLARATIONS NodePtr head; NodePtr ptr; Declarations for a Dynamic Linked List. prev. info. next 5000 A 6000

67 Pointer Dereferencing and Member Selection. info. next A 6000 ptr. info. next A 6000 *ptr ptr. info. next (*ptr).info ptr->info A 6000

68 ptr is a Pointer to a Node. info. next A 6000 ptr

69 *ptr is the Entire Node Pointed to by ptr ptr. info. next A 6000 *ptr

70 ptr->info Is a Node Member ptr. info. next ptr->info (*ptr).info // equivalent A 6000

71 ptr->link Is a Node Member ptr. info. next ptr->next (*ptr).next // equivalent A 6000

Lists 72 Inserting a Node into a Single Linked List Node* bob = new Node("Bob"); bob->next = harry->next; // step 1 harry->next = bob; // step 2

Lists 73 Removing a node from a single-linked list Node* ptr = tom->next; tom->next = tom->next->next; delete ptr;

Lists 74 Inserting into a Double-Linked List DNode* sharon = new DNode("Sharon"); // Link new DNode to its neighbors sharon->next = sam; // Step 1 sharon->prev = sam->prev; // Step 2

Lists 75 Inserting into a Double-Linked List (2) // Link old predicessor of sam to new predicessor. sam->prev->next = sharon; // Step 3 // Link to new predicessor. sam->prev = sharon; // Step 4

Lists 76 Removal from a Double-Linked List harry->prev->next = harry->next; // Step 1 harry->next->prev = harry->prev; // Step 2 delete harry;

Lists 77

Lists 78

Lists 79

Lists 80

Lists 81

Lists 82 /** Construct an empty list. */ list() { node = new list_node(); node->next = node; node->prev = node; length = 0; }

Lists 83

Lists 84

Lists 85

Lists 86

Lists 87

Lists 88

Lists 89

Lists 90

Lists 91

Lists 92 Linked Lists in Arrays Begin with a large workspace array and regard the array as our allocation of unused space. Set up functions to keep track of which parts of the array are unused and to link entries of the array together in the desired order. The one feature of linked lists that you invariably lose in this implementation method is the dynamic allocation of storage.

Lists 93 Linked Lists in Arrays Applications where linked lists in arrays may prove preferable are those where: The number of entries in a list is known in advance, The links are frequently rearranged, but relatively few additions or deletions are made, or The same data are sometimes best treated as a linked list and other times as a contiguous list.

Lists 94 Example

Lists 95

Lists 96 Implementations What are the data members? What is the logic for insert and delete? How would you keep track of the iterator?

Lists 97 Set Position How would you implement the following: Singly linked Doubly linked Array based implementation template Node *List ::set_position (int position) const; // Pre: position is a valid position in the List; 0 <= position < count // Post: Returns a pointer to the Node in position

Lists 98 Insert Function template void List ::insert ( int position, const List_entry &x);

Lists 99 Summary Slide 1 §- list -A Sequence of elements stored by position. -Index access is not available… §-to access the value of an element, must pass through its preceding elements. §- list iterator -A generalized pointer that moves through a list element by element… forward or backward -At any point, the * operator accesses the value of a list item.

Lists Summary Slide 2 §- The list class has two iterator types: 1)iterator 1)iterator: A generalized list traversal pointer. 2)const_iterator 2)const _ iterator: :: must be used with a constant list object. Each type is a nested class of list and must be accessed by using the scope operator ::

Lists Summary Slide 3 §- the list member function begin() -Gives an iterator an initial value that points to the first element. §- the list member function end() -Returns an iterator pointing just past the last element of the list.

Lists Summary Slide 4 §- The sequential search of a list object firstlast -implemented by using an iterator range [first, last). last -It returns an iterator that points at the target value or has value last if the target is not in the list.

Lists Summary Slide 5 §- list class member f ns insert() and erase() -Both use an iterator argument to modify a list. 1)insert() pos 1)insert(): places value in the list before the data referenced by the iterator pos. 2)erase() pos 2)erase(): removes the data item referenced by pos from the list.

Lists Summary Slide 6 §- singly linked lists -Each node contains a value and a pointer to the next node in the list. -The list begins with a pointer to the first node of the list and terminates when a node has a NULL pointer.

Lists Summary Slide 7 §- Inserting/Deleting at the front of a singly linked list 1)Insert -Set the pointer in the new node to the previous value of front. -update front to point at the new node. 2)Erase -assign front the pointer value of the first node, and then delete the node.

Lists Summary Slide 8 §- Inserting/Erasing inside a singly linked list -Maintain a pointer to the current list node and a pointer to the previous node. -Change the pointer value in the previous node.

Lists Summary Slide 9 §- Insert/Delete at the back of a singly linked list -Maintain a pointer to the last list node that has value NULL when the list is empty. -Assign a back pointer the address of the first node added to the list. -To add other nodes at the back: 1)allocate a new node 2)assign the pointer in node back to point to the new node 3)assign the pointer back the address of the new node.

Lists Summary Slide 10 §- Doubly linked lists -provide the most flexible implementation for the sequential list. §- Its nodes have pointers to the next and the previous node, so the program can traverse a list in either the forward or backward direction. -Traverse a list by starting at the first node and follow the sequence of next nodes until you arrive back at the header. -To traverse a list in reverse order, start at the last node and follow the sequence of previous nodes until arriving back at the header.