1 / 37

Singly Linked Lists: Implementation and Terminologies

Learn about singly linked lists data structure, node class, insertion/removal methods, stack and queue implementation, double linked lists, performance analysis, and graph terminologies.

dshanna
Download Presentation

Singly Linked Lists: Implementation and Terminologies

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. Part-B3Linked Lists Linked Lists

  2. Singly Linked List (§ 4.4.1) • A singly linked list is a concrete data structure consisting of a sequence of nodes • Each node stores • element • link to the next node next node elem  A B C D Linked Lists

  3. The Node Class for List Nodes(the file is source/Node.java) public class Node { // Instance variables: private Object element; private Node next; /** Creates a node with null references to its element and next node. */ public Node() { this(null, null); } /** Creates a node with the given element and next node. */ public Node(Object e, Node n) { element = e; next = n; } // Accessor methods: public Object getElement() { return element; } public Node getNext() { return next; } // Modifier methods: public void setElement(Object newElem) { element = newElem; } public void setNext(Node newNext) { next = newNext; } } Linked Lists

  4. Allocate a new node update new element Have new node point to old head Update head to point to new node Inserting at the Head Linked Lists

  5. Removing at the Head • Update head to point to next node in the list • Allow garbage collector to reclaim the former first node Linked Lists

  6. Inserting at the Tail • Allocate a new node • Insert new element • Have new node point to null • Have old last node point to new node • Update tail to point to new node Linked Lists

  7. Removing at the Tail • Removing at the tail of a singly linked list is not efficient! • There is no constant-time way to update the tail to point to the previous node The interface of data structure list is in List.java. The implementation is in NodeList.java. But it uses DNode.java. Actually, it is doubly linked list. Linked Lists

  8. Stack with a Singly Linked List • We can implement a stack with a singly linked list • The top element is stored at the first node of the list • The space used is O(n) and each operation of the Stack ADT takes O(1) time nodes t  elements Linked Lists

  9. Queue with a Singly Linked List • We can implement a queue with a singly linked list • The front element is stored at the first node • The rear element is stored at the last node • The space used is O(n) and each operation of the Queue ADT takes O(1) time r nodes f  elements Linked Lists

  10. The List ADT models a sequence of positions storing arbitrary objects It establishes a before/after relation between positions Generic methods: size(), isEmpty() Accessor methods: first(), last() prev(p), next(p) Update methods: replace(p, e) insertBefore(p, e), insertAfter(p, e), insertFirst(e), insertLast(e) remove(p) List ADT (§ 5.2.3) Linked Lists

  11. Doubly Linked List prev next • A doubly linked list provides a natural implementation of the List ADT • Nodes implement Position and store: • element • link to the previous node • link to the next node • Special trailer and header nodes elem node trailer nodes/positions header elements Linked Lists

  12. Insertion p • We visualize operation insertAfter(p, X), which returns position q A B C p q A B C X p q A B X C Linked Lists

  13. Insertion Algorithm Algorithm insertAfter(p,e): Create a new node v v.setElement(e) v.setPrev(p) {link v to its predecessor} v.setNext(p.getNext()) {link v to its successor} (p.getNext()).setPrev(v) {link p’s old successor to v} p.setNext(v) {link p to its new successor, v} return v {the position for the element e} Linked Lists

  14. p A B C D Deletion • We visualize remove(p), where p = last() A B C p D A B C Linked Lists

  15. Deletion Algorithm Algorithm remove(p): t = p.element {a temporary variable to hold the return value} (p.getPrev()).setNext(p.getNext()) {linking out p} (p.getNext()).setPrev(p.getPrev()) p.setPrev(null) {invalidating the position p} p.setNext(null) return t Linked Lists

  16. Performance • In the implementation of the List ADT by means of a doubly linked list • The space used by a list with n elements is O(n) • The space used by each position of the list is O(1) • All the operations of the List ADT run in O(1) time • Operation element() of the Position ADT runs in O(1) time Linked Lists

  17. Terminologies • A Graph G=(V,E):V---set of vertices and E--set of edges. • Path in G: sequence v1, v2, ..., vk of vertices in V such that(vi, vi+1) is in E. • vi and vj could be the same • Simple path in G: asequence v1, v2, ..., vk of distinct vertices in V such that(vi, vi+1) is in E. • vi and vj can not be the same Linked Lists

  18. Example: Simple path A path, but not simple Linked Lists

  19. Terminologies (continued) • Circuit: A path v1, v2, ..., vksuch that v1 = vk . • Simple circuit: a circuit v1, v2, ..., vk,where v1=vk and vivj for any 1<i, j<k. Linked Lists

  20. Euler circuit • Input: a graph G=(V, E) • Problem: is there a circuit in G that uses each edge exactly once. Note:G can have multiple edges, .i.e., two or more edges connect vertices u and v. Linked Lists

  21. Story: • The problem is called Konigsberg bridge problem • it asks if it is possible to take a walk in the town shown in Figure 1 (a) crossing each bridge exactly once and returning home. • solved by Leonhard Euler [pronounced OIL-er] (1736) • The first problem solved by using graph theory • A graph is constructed to describe the town. (See Figure 1 (b).) Linked Lists

  22. The original Konigsberg bridge(Figure 1) Linked Lists

  23. Theorem for Euler circuit (proof is not required) Theorem 1 (Euler’s Theorem) The graph has an Euler circuit if and only if all the vertices of a connected graph have even degree. Proof: (if) Going through the circuit, each time a vertex is visited, the degree is increased by 2. Thus, the degree of each vertex is even. Linked Lists

  24. Proof of Theorem 1:(only if) We give way to find an Euler circuit for a graph in which every vertex has an even degree.  Since each node v has even degree, when we first enter v, there is an unused edge that can be used to get out v.  The only exception is when v is a starting node.  Then we get a circuit (may not contain all edges in G)  If every node in the circuit has no unused edge, all the edges in G have been used since G is connected.  Otherwise, we can construct another circuit, merge the two circuits and get a larger circuit.  In this way, every edge in G can be used. Linked Lists

  25. An example for Theorem 1: 4 1 5 d d d 7 6 a a a b b b b e e e e 3 2 2 f f f 1 3 after merge c c c c 11 2 10 3 1 g g 13 12 5 4 7 6 9 4 h h i i 8 7 13 j j 12 8 11 6 5 10 9 Linked Lists

  26. An efficient algorithm for Euler circuit 1. Starting with any vertex u in G, take an unused edge (u,v) (if there is any) incident to u 2. Do Step 1 for v and continue the process until v has no unused edge. (a circuit C is obtained) 3. If every node in C has no unused edge, stop. 4. Otherwise, select a vertex, say, u in C, with some unused edge incident to u and do Steps 1 and 2 until another circuit is obtained. 5. Merge the two circuits obtained to form one circuit 6. Continue the above process until every edge in G is used. Linked Lists

  27. Euler Path A path which contains all edges in a graph G is called an Euler path of G. Corollary: A graph G=(V,E) which has an Euler path has 2 vertices of odd degree. Linked Lists

  28. Proof of the Corollary Suppose that a graph which has an Euler path starting at u and ending at v, where uv.  Creating a new edge e joining u and v, we have an Euler circuit for the new graph G’=(V, E{e}).  From Theorem 1, all the vertices in G’ have even degree. Remove e.  Then u and v are the only vertices of odd degree in G. (Nice argument, not required for exam.) Linked Lists

  29. Representations of Graphs • Two standard ways • Adjacency-list representation • Space required O(|E|) • Adjacency-matrix representation • Space required O(n2). • Depending on problems, both representations are useful. Linked Lists

  30. 2 5 / 1 2 1 1 5 3 4 3 2 / / / 2 2 4 / 3 3 5 2 4 5 4 1 4 5 (a) (b) Adjacency-list representation • Let G=(V, E) be a graph. • V– set of nodes (vertices) • E– set of edges. • For each uV, the adjacency list Adj[u] contains all nodes in V that are adjacent to u. Linked Lists

  31. 1 2 3 4 5 1 2 3 4 5 0 1 0 0 1 1 0 1 1 1 0 1 0 1 0 0 1 1 0 1 1 1 0 1 0 2 1 3 5 4 (a) (c) Adjacency-matrix representation • Assume that the nodes are numbered 1, 2, …, n. • The adjacency-matrix consists of a |V||V| matrix A=(aij) such that aij= 1 if (i,j) E, otherwise aij= 0. Linked Lists

  32. Implementation of Euler circuit algorithm (Not required) • Data structures: • Adjacency matrix • Also, we have two lists to store the circuits • One for the circuit produced in Steps 1-2. • One for the circuit produced in Step 4 • We can merge the two lists in O(n) time. In Step 1: when we take an unused edge (u, v), this edge is deleted from the adjacency matrix. Linked Lists

  33. Implementation of Euler circuit algorithm In Step 2: if all cells in the column and row of v is 0, v has no unused edge. • Testing whether v has no unused edge. • A circuit (may not contain all edges) is obtained if the above condition is true. In Step 3: if all the element’s in the matrix are 0, stop. In step 4: if some elements in the matrix is not 0, continue. Linked Lists

  34. Summary of Euler circuit algorithm • Design a good algorithm needs two parts • Theorem, high level part • Implementation: low level part. Data structures are important. • We will emphasize both parts. Linked Lists

  35. Summary (Subject to change) • Understand singly linked list • How to create a list • insert at head, insert at tail, remove at head and remove at tail. • Should be able to write program using singly linked list • We will have chance to practice this. • Know the concept of doubly linked list. • No time to write program about this. • Euler Circuit • Understand the ideas • No need for the implementation. Linked Lists

  36. My Questions: (not part of the lecture) • Have you learn recursive call? • A function can call itself. . Example: f(n)=n!=n×(n-1)×(n-2)×…×2×1 and 0!=1. It can also be written as f(n)=n×f(n-1) and f(0)=1. Java code: Public static int recursiveFactorial(int n) { if (n==0) return 1; else return n*recursiveFactorial(n-1); } Linked Lists

  37. Remks • Delete Euler Circuit • They do not like programming, especially, complicated programming work. Linked Lists

More Related