1 / 24

Efficient List Data Structures Handbook

Learn about Abstract Data Types, List Operations, Implementations, Running Times, and more. Array vs. Pointer Implementations with Simple Examples. 8

carya
Download Presentation

Efficient List Data Structures Handbook

An Image/Link below is provided (as is) to download presentation Download Policy: Content on the Website is provided to you AS IS for your information and personal use and may not be sold / licensed / shared on other websites without getting consent from its author. Content is provided to you AS IS for your information and personal use only. Download presentation by click this link. While downloading, if for some reason you are not able to download a presentation, the publisher may have deleted the file from their server. During download, if you can't get a presentation, the file might be deleted by the publisher.

E N D

Presentation Transcript


  1. Lists CSE 373 Data Structures Lecture 3

  2. Readings • Reading • Section 3.1 ADT (recall, lecture 1): • Abstract Data Type (ADT): Mathematical description of an object with set of operations on the object. • Section 3.2 The List ADT Lists - Lecture 3

  3. List ADT • What is a List? • Ordered sequence of elements A1, A2, …, AN • Elements may be of arbitrary type, but all are of the same type • Common List operations are: • Insert, Find, Delete, IsEmpty, IsLast, FindPrevious, First, Kth, Last, Print, etc. Lists - Lecture 3

  4. Simple Examples of List Use • Polynomials • 25 + 4x2 + 75x85 • Unbounded Integers • 4576809099383658390187457649494578 • Text • “This is an example of text” Lists - Lecture 3

  5. List Implementations • Two types of implementation: • Array-Based • Pointer-Based Lists - Lecture 3

  6. 0 1 2 3 … count-1 MAX_SIZE-1 A1 A2 A3 A4 … AN List: Array Implementation • Basic Idea: • Pre-allocate a big array of size MAX_SIZE • Keep track of current size using a variable count • Shift elements when you have to insert or delete Lists - Lecture 3

  7. List: Array Implementation Insert Z in kth position 0 1 2 3 4 5 MAX_SIZE-1 A B C D E F 0 1 2 3 4 5 6 MAX_SIZE-1 A B Z C D E F Lists - Lecture 3

  8. Array List Insert Running Time • Running time for N elements? • On average, must move half the elements to make room – assuming insertions at positions are equally likely • Worst case is insert at position 0. Must move all N items one position before the insert • This is O(N) running time. Probably too slow Lists - Lecture 3

  9. Review Big Oh Notation • T(N) = O(f(N)) if there are positive constants c and n0 such that: T(N) < c f(N) when N >n0 • T(N) = O(N) linear Lists - Lecture 3

  10. List: Pointer Implementation • Basic Idea: • Allocate little blocks of memory (nodes) as elements are added to the list • Keep track of list by linking the nodes together • Change links when you want to insert or delete L node node Value Next Value Next NULL Lists - Lecture 3

  11. Pointer-Based Linked List pL node node Value Next Value Next NULL Lists - Lecture 3

  12. Pointer-based Insert (after p) L node node Value Next Value Next NULL P Value E Next Insert the value E after P Lists - Lecture 3

  13. Insertion After InsertAfter(p : node pointer, v : thing): { x : node pointer; x := new node; x.value := v; x.next := p.next; p.next := x; } Lists - Lecture 3

  14. Linked List with Header Node L header node first actual list node Value ignore Next Next Value NULL Advantage: “insert after” and “delete after” can be done at the beginning of the list. Lists - Lecture 3

  15. Pointer Implementation Issues • Whenever you break a list, your code should fix the list up as soon as possible • Draw pictures of the list to visualize what needs to be done • Pay special attention to boundary conditions: • Empty list • Single item – same item is both first and last • Two items – first, last, but no middle items • Three or more items – first, last, and middle items Lists - Lecture 3

  16. Pointer List Insert Running Time • Running time for N elements? • Insert takes constant time (O(1)) • Does not depend on input size • Compare to array based list which is O(N) Lists - Lecture 3

  17. Linked List Delete L node node Value Next Next Value NULL P To delete the node pointed to by P, need a pointer to the previous node; See book for findPrevious method Lists - Lecture 3

  18. Doubly Linked Lists • findPrevious (and hence Delete) is slow [O(N)] because we cannot go directly to previous node • Solution: Keep a "previous" pointer at each node head prev prev prev Lists - Lecture 3

  19. Double Link Pros and Cons • Advantage • Delete (not DeleteAfter) and FindPrev are faster • Disadvantages: • More space used up (double the number of pointers at each node) • More book-keeping for updating the two pointers at each node (pretty negligible overhead) Lists - Lecture 3

  20. Unbounded Integers Base 10 • -4572 • 348 X : node pointer 103 102 101 100 sign null 4 5 7 2 -1 Y : node pointer 102 101 100 sign null 3 4 8 1 Lists - Lecture 3

  21. Zero null -1 1 null Lists - Lecture 3

  22. Recursive Addition • Positive numbers (or negative numbers) 3427 +898 7 +8 5 10 342 +89 Recursive calls +1 Lists - Lecture 3

  23. Recursive Addition • Mixed numbers 3427 -898 7 -8 9 -10 342 -89 Recursive calls -1 Lists - Lecture 3

  24. Example • Mixed numbers 1000000 -999999 0 -9 1 -10 100000 -99999 1 -1 0 Recursive calls Lists - Lecture 3

More Related