14 Graph ADTs  Graph concepts.  Graph applications.  A graph ADT: requirements, contract.  Implementations of graphs: edge-set, adjacency-set, adjacency-matrix.

Slides:



Advertisements
Similar presentations
Topological Sort Topological sort is the list of vertices in the reverse order of their finishing times (post-order) of the depth-first search. Topological.
Advertisements

CSE 373, Copyright S. Tanimoto, 2001 Graphs Graphs 2 Incidence and Adjacency Representing a graph with an adjacency matrix, an incidence matrix,
PSU CS Algorithms Analysis and Design Graphs.
CS 206 Introduction to Computer Science II 03 / 27 / 2009 Instructor: Michael Eckmann.
Graphs Chapter 12. Chapter Objectives  To become familiar with graph terminology and the different types of graphs  To study a Graph ADT and different.
Chapter 8, Part I Graph Algorithms.
Graph Search Methods Spring 2007 CSE, POSTECH. Graph Search Methods A vertex u is reachable from vertex v iff there is a path from v to u. A search method.
© 2006 Pearson Addison-Wesley. All rights reserved14 A-1 Chapter 14 excerpts Graphs (breadth-first-search)
Data Structures Using C++
Graphs Graphs are the most general data structures we will study in this course. A graph is a more general version of connected nodes than the tree. Both.
Data Structure and Algorithms (BCS 1223) GRAPH. Introduction of Graph A graph G consists of two things: 1.A set V of elements called nodes(or points or.
CS 206 Introduction to Computer Science II 11 / 11 / Veterans Day Instructor: Michael Eckmann.
ITEC200 – Week 12 Graphs. 2 Chapter Objectives To become familiar with graph terminology and the different types of graphs To study.
Graph & BFS.
Nyhoff, ADTs, Data Structures and Problem Solving with C++, Second Edition, © 2005 Pearson Education, Inc. All rights reserved Graphs.
Graphs.
Graphs. Graph definitions There are two kinds of graphs: directed graphs (sometimes called digraphs) and undirected graphs Birmingham Rugby London Cambridge.
Introduction to Graphs
Graphs Chapter 12. Chapter 12: Graphs2 Chapter Objectives To become familiar with graph terminology and the different types of graphs To study a Graph.
Spring 2010CS 2251 Graphs Chapter 10. Spring 2010CS 2252 Chapter Objectives To become familiar with graph terminology and the different types of graphs.
CS 206 Introduction to Computer Science II 11 / 03 / 2008 Instructor: Michael Eckmann.
Graphs & Graph Algorithms 2 Nelson Padua-Perez Bill Pugh Department of Computer Science University of Maryland, College Park.
Graphs & Graph Algorithms 2
CS 206 Introduction to Computer Science II 11 / 05 / 2008 Instructor: Michael Eckmann.
CS 206 Introduction to Computer Science II 03 / 25 / 2009 Instructor: Michael Eckmann.
CS 206 Introduction to Computer Science II 11 / 09 / 2009 Instructor: Michael Eckmann.
Fall 2007CS 2251 Graphs Chapter 12. Fall 2007CS 2252 Chapter Objectives To become familiar with graph terminology and the different types of graphs To.
Graphs & Graph Algorithms 2 Fawzi Emad Chau-Wen Tseng Department of Computer Science University of Maryland, College Park.
© 2006 Pearson Addison-Wesley. All rights reserved14 A-1 Chapter 14 Graphs.
Chapter 14 Graphs. © 2004 Pearson Addison-Wesley. All rights reserved Terminology G = {V, E} A graph G consists of two sets –A set V of vertices,
Representing and Using Graphs
Nyhoff, ADTs, Data Structures and Problem Solving with C++, Second Edition, © 2005 Pearson Education, Inc. All rights reserved Graphs.
Nyhoff, ADTs, Data Structures and Problem Solving with C++, Second Edition, © 2005 Pearson Education, Inc. All rights reserved Graphs.
Graphs. 2 Graph definitions There are two kinds of graphs: directed graphs (sometimes called digraphs) and undirected graphs Birmingham Rugby London Cambridge.
Graphs CSE 2011 Winter June Graphs A graph is a pair (V, E), where  V is a set of nodes, called vertices  E is a collection of pairs.
Graphs. Made up of vertices and arcs Digraph (directed graph) –All arcs have arrows that give direction –You can only traverse the graph in the direction.
Nyhoff, ADTs, Data Structures and Problem Solving with C++, Second Edition, © 2005 Pearson Education, Inc. All rights reserved Graphs.
Graphs. Definitions A graph is two sets. A graph is two sets. –A set of nodes or vertices V –A set of edges E Edges connect nodes. Edges connect nodes.
CISC 235: Topic 9 Introduction to Graphs. CISC 235 Topic 92 Outline Graph Definition Terminology Representations Traversals.
Graphs. Graphs Similar to the graphs you’ve known since the 5 th grade: line graphs, bar graphs, etc., but more general. Those mathematical graphs are.
Graphs A graphs is an abstract representation of a set of objects, called vertices or nodes, where some pairs of the objects are connected by links, called.
Copyright © 2007 Pearson Education, Inc. Publishing as Pearson Addison-Wesley. Ver Chapter 13: Graphs Data Abstraction & Problem Solving with C++
1 Directed Graphs Chapter 8. 2 Objectives You will be able to: Say what a directed graph is. Describe two ways to represent a directed graph: Adjacency.
COSC 2007 Data Structures II
Graphs Chapter 12. Chapter 12: Graphs2 Chapter Objectives To become familiar with graph terminology and the different types of graphs To study a Graph.
© 2006 Pearson Addison-Wesley. All rights reserved 14 A-1 Chapter 14 Graphs.
Graphs Upon completion you will be able to:
Graphs and Paths : Chapter 15 Saurav Karmakar
Chapter 20: Graphs. Objectives In this chapter, you will: – Learn about graphs – Become familiar with the basic terminology of graph theory – Discover.
90-723: Data Structures and Algorithms for Information Processing Copyright © 1999, Carnegie Mellon. All Rights Reserved. 1 Lecture 7: Graphs Data Structures.
Graphs and Shortest Paths Using ADTs and generic programming.
Data Structures and Algorithm Analysis Graph Algorithms Lecturer: Jing Liu Homepage:
Lecture #13. Topics 1.The Graph Abstract Data Type. 2.Graph Representations. 3.Elementary Graph Operations.
1 GRAPHS – Definitions A graph G = (V, E) consists of –a set of vertices, V, and –a set of edges, E, where each edge is a pair (v,w) s.t. v,w  V Vertices.
Lecture 20. Graphs and network models 1. Recap Binary search tree is a special binary tree which is designed to make the search of elements or keys in.
BCA-II Data Structure Using C Submitted By: Veenu Saini
Chapter 13: The Graph Abstract Data Type
Graphs.
CMSC 341 Lecture 21 Graphs (Introduction)
Graphs & Graph Algorithms 2
Graphs Chapter 13.
Graphs Chapter 11 Objectives Upon completion you will be able to:
Graphs.
Graphs.
Chapter 14 Graphs © 2006 Pearson Addison-Wesley. All rights reserved.
Graphs.
Graphs.
Graphs.
Chapter 14 Graphs © 2011 Pearson Addison-Wesley. All rights reserved.
Graphs.
Presentation transcript:

14 Graph ADTs  Graph concepts.  Graph applications.  A graph ADT: requirements, contract.  Implementations of graphs: edge-set, adjacency-set, adjacency-matrix representations.  Graph algorithms: traversal, search, shortest distance, shortest path. © 2008 David A Watt, University of Glasgow Algorithms & Data Structures (M)

14-2 Graph concepts (1)  A graph consists of vertices connected by edges in an arbitrary manner.  Each vertex (or node) contains a single element.  Each edge connects two vertices together.  Each edge may optionally contain an edge attribute.  The size of a graph is the number of vertices.  The empty graph has no vertices (and therefore no edges).

14-3 Graph concepts (2)  In an undirected graph, edges have no direction:  In a directed graph, each edge has a particular direction: W V X TU W S W V X TU W S undirected edges vertices directed edges

14-4 W V X TU W S Graph concepts (3)  A path in a graph is a list of vertices, such that each pair of consecutive vertices is connected by an edge in the graph.  In a directed graph, a path must respect the directions of the edges. «S, T, W, V » is a path.«S, T, U, V » is a path. «S, T, W, V» is not a path. W V X TU W S

14-5 Graph applications  A road network is an undirected graph in which each vertex is a place and each edge is a road connecting two places. (The edge attributes might be road numbers or distances.)  A computer network is an undirected graph in which each vertex is a computer and each edge is a point-to-point connection.  The World-Wide Web is a directed graph in which each vertex is a document and each edge is a hyperlink.

14-6 Example: road network  Simplified road network for GB and Ireland: London Edinburgh Glasgow Carlisle Manchester Birmingham Bristol Exeter Swansea Liverpool Leeds Rugby Hull Cambridge Dover Southampton Newcastle Dublin Belfast «Edinburgh, Newcastle, Leeds» is not a path. «Dover, London, Bristol, Exeter» is a path.

14-7 Graph concepts (4)  A cycle in a graph is a path whose first and last vertices are the same.  A cyclic graph is one that contains at least one cycle. An acyclic graph is one that contains no cycle. This graph is cyclic, since «T, U, V, W, T» is a cycle. W V X TU W S This graph is acyclic. D C A B

14-8 Graph terminology (1)  Two vertices of a graph are neighbours if they are connected by an edge.  The degree of a vertex is the number of edges connecting it with other vertices. U’s neighbours are T, V, X. U’s degree is 3. W V X TU W S

14-9 Graph terminology (2)  In a directed graph, if e is an edge connecting vertex v to vertex w: –v is the source of e, and w is the destination of e. –e is an in-edge of w, and an out-edge of v. –w is a successor of v, and v is a predecessor of w.  In a directed graph: –the in-degree of a vertex is its number of in-edges; –the out-degree of a vertex is its number of out-edges. U’s in-degree is 1. Its out-degree is 2. e vw W V X TU W S

14-10 Graph ADT: requirements (1)  Requirements (for both undirected and directed graphs): 1)It must be possible to make a graph empty. 2)It must be possible to add a new vertex, or to add a new edge connecting two existing vertices. 3)It must be possible to remove a vertex (and all of its connecting edges), or to remove a given edge. 4)It must be possible to test whether a graph has an edge connecting two given vertices. 5)It must be possible to access all vertices or all edges. 6)It must be possible to access all neighbours, or all connecting edges, of a given vertex.

14-11 Graph ADT: requirements (2)  Requirements (continued): 7)It must be possible to inspect or update the element contained in a given vertex. 8)It must be possible to inspect or update the attribute (if any) contained in a given edge.  Additional requirement for directed graphs only: 9)It must be possible to access all successors, or all out- edges, of a given vertex in a directed graph.  Note: Vertices and edges must be visible outside the graph ADT.

14-12 Graph ADT: contract (1)  Possible contract for all graphs: public interface Graph { // Each Graph object is a (directed or // undirected) graph whose elements are of type E // and whose edge attributes are of type A.

14-13 Graph ADT: contract (2)  Possible contract (continued): //////////// Accessors //////////// public int size (); // Return the number of vertices in this graph. public int degree (Vertex v); // Return the number of edges connecting vertex v in // this graph. public boolean containsEdge ( Vertex v0, Vertex v1); // Return true if and only if these is an edge // connecting vertices v0 and v1 in this graph. (If the // graph is directed, v0 is the edge’s source and v1 is // its destination.)

14-14 Graph ADT: contract (3)  Possible contract (continued): //////////// Transformers //////////// public void clear (); // Make this graph empty. public Vertex addVertex (E elem); // Add to this graph a new vertex containing elem // but with no connecting edges, and return the new // vertex. public Edge addEdge ( Vertex v0, Vertex v1); // Add to this graph a new edge connecting vertices // v0 and v1, but containing no attribute, and return // the new edge. (If the graph is directed, v0 is the // edge ’ s source and v1 is its destination.)

14-15 Graph ADT: contract (4)  Possible contract (continued): public Edge addEdge ( Vertex v0, Vertex v1, A attr); // Add to this graph a new edge connecting vertices // v0 and v1, and containing edge attribute attr, // and return the new edge. (If the graph is directed, // v0 is the edge ’ s source and v1 is its destination.) public void removeVertex (Vertex v); // Remove vertex v from this graph, together with all // its connecting edges. public void removeEdge (Edge e); // Remove edge e from this graph.

14-16 Graph ADT: contract (5)  Possible contract (continued): //////////// Iterators //////////// public Iterator vertices (); // Return an iterator that will visit all vertices of this // graph, in no particular order. public Iterator edges (); // Return an iterator that will visit all edges of this // graph, in no particular order.

14-17 Graph ADT: contract (6)  Possible contract (continued): public Iterator neighbours ( Vertex v); // Return an iterator that will visit all neighbours of // vertex v in this graph, in no particular order. public Iterator connectingEdges ( Vertex v); // Return an iterator that will visit all connecting edges // of vertex v in this graph, in no particular order.

14-18 Graph ADT: contract (7)  Possible contract (continued): //////// Inner interface for vertices //////// public interface Vertex { // Each Vertex object is a graph vertex, and // contains a single element. public E getElement (); // Return the element contained in this vertex. public void setElement (E elem); // Change the element contained in this vertex to // be elem. }

14-19 Graph ADT: contract (8)  Possible contract (continued): //////// Inner interface for edges //////// public interface Edge { // Each Edge object is a graph edge, and // optionally contains a single attribute. public A getAttribute (); // Return the attribute of this edge, or null if there // is none. public void setAttribute (A attr); // Change the attribute contained in this edge to // attr.

14-20 Graph ADT: contract (9)  Possible contract (continued): public Vertex[] getVertices (); // Return an array containing the two vertices // connected by this edge. (If the graph is directed, // the array will contain the edge ’ s source and // destination vertices in that order.) } }

14-21 Directed graph ADT: contract (1)  Possible contract for directed graphs: public interface Digraph extends Graph { // Each Digraph object is a directed graph // whose elements are of type E and whose edge // attributes are of type A. //////////// Accessor //////////// public int outDegree (Vertex v); // Return the number of out-edges of vertex v in this // graph.

14-22 Directed graph ADT: contract (2)  Possible contract (continued): //////////// Iterators //////////// public Iterator successors ( Vertex v); // Return an iterator that will visit all successors of // vertex v in this directed graph, in no particular // order. public Iterator outEdges ( Vertex v); // Return an iterator that will visit all out-edges of // vertex v in this directed graph, in no particular // order. }

14-23 Implementation of graphs using edge-sets (1)  Represent a graph by a vertex-set and an edge- set.  Make each edge contain links to the two vertices it connects.  Represent the vertex-set by a DLL. (This speeds up deletion of a given vertex.)  Represent the edge-set by a DLL. (This speeds up deletion of a given edge.)

14-24 Implementation of graphs using edge-sets (2)  Illustration: a b c d e f g edges S T U V W X vertices W abf e c d g V X TU W S elem. attr. link to source link to destination links to other edges links to other vertices Key: vertex edge

14-25 Implementation of graphs using edge-sets (3)  Summary of algorithms (letting n e be the number of edges): OperationAlgorithm Time complexity containsEdge linear search through edge-set DLLO(ne)O(ne) addVertex insertion at front of vertex-set DLLO(1) addEdge insertion at front of edge-set DLLO(1) removeVertex deletion in vertex-set DLL, plus multiple deletions in edge-set DLL O(ne)O(ne) removeEdge deletion in edge-set DLLO(1)

14-26 Implementation of graphs using edge-sets (4)  If the graph is directed: –The outEdges and successors iterators must traverse the entire edge-set to find all the given vertex’s out-edges and successors. So both iterators have time complexity O(n e ).  How would this be affected if the graph is undirected?

14-27 Implementation of graphs using adjacency-sets (1)  Represent a graph by a vertex-set together with an adjacency-set for each vertex. –Each adjacency-set contains only the edges connecting a particular vertex.  Make each vertex contain a link to its adjacency- set.  Make each edge contain links to the two vertices it connects.  Represent the vertex-set by a DLL (as before).  Represent each adjacency-set by a SLL (since it is typically small).

14-28 Implementation of graphs using adjacency-sets (2)  Illustration: S T U V W X vertices b c f d e a g elem. attr. link to source link to destination link to another edge links to other vertices Key: vertex edge link to adj. set W abf e c d g V X TU W S

14-29 Implementation of graphs using adjacency matrices (3)  Summary of algorithms (letting n e be the number of edges, and letting d be the maximum degree of a vertex): OperationAlgorithm Time complexity containsEdge linear search through adjacency-set SLLO(d)O(d) addVertex insertion at front of vertex-set DLLO(1) addEdge insertion at front of adjacency-set SLLO(1) removeVertex deletion in vertex-set DLL, plus traversal of all adjacency-set SLLs to find and delete connecting edges O(ne)O(ne) removeEdge deletion in adjacency-set SLLO(d)O(d)

14-30 Implementation of graphs using adjacency-sets (4)  If the graph is directed: –Store only the out-edges in each vertex’s adjacency- set. (So each edge is stored only once.) –The outEdges and successors iterators need traverse only the given vertex’s adjacency-set. So both iterators have time complexity O(d).  How would this be affected if the graph is undirected?

14-31 Implementation of bounded graphs using adjacency-matrices (1)  Represent a bounded graph (size  m) by an m × m matrix. Allocate a unique number in the range 0 … m–1 to each vertex.  The vertex-set is represented by an array a, indexed by vertex numbers, containing links to the adjacency-sets.  Each vertex’s adjacency-set is itself represented by an array, indexed by vertex numbers.  If vertex v is connected to vertex w, then a[v][w] contains a link to the edge object.

14-32 Implementation of bounded graphs using adjacency-matrices (2)  Illustration (with m = 10): S 0 T 1 U 2 V 3 W 4 X b c f d e ag Key: source dest. attr. elem. vertex edge link to adj. set W abf e c d g V X TU W S

14-33 Implementation of bounded graphs using adjacency-matrices (3)  Summary of algorithms: OperationAlgorithm Time complexity containsEdge matrix indexingO(1) addVertex finding a cleared matrix row and columnO(m)O(m) addEdge matrix indexingO(1) removeVertex clearing a matrix row and columnO(m)O(m) removeEdge matrix indexingO(1)

14-34 Implementation of bounded graphs using adjacency-matrices (4)  Advantages and disadvantages of the adjacency- matrix representation: + The containsEdge, addEdge and removeEdge operations are very fast. – The space required is about m 2. This is wasteful if there are relatively few edges. – The graph is restricted to at most one edge connecting any pair of vertices.

14-35 Implementation of bounded graphs using adjacency-matrices (5)  If the graph is directed: –If an edge connects vertex v to vertex w, store a link to the edge object in a[v][w] but not in a[w][v]. This reflects the edge’s direction. –The outEdges and successors iterators must traverse a whole row of the matrix. So both iterators have time complexity O(m).  How would this be affected if the graph is undirected?

14-36 Graph traversal (1)  A graph traversal problem entails finding all vertices that can be reached from a given starting vertex. E.g.: –Find all places that can be reached by road from Glasgow.  Algorithms to solve such problems must follow all possible paths from the starting vertex, visiting each vertex reached along these paths.

14-37 Graph traversal (2)  A graph traversal algorithm could reach the same vertex along several different paths.  So it must “mark” each vertex the first time it is reached, to avoid visiting the same vertex repeatedly. (Otherwise traversal of a cyclic graph would never terminate.)  Alternative ways to mark vertices: –Store a boolean flag in each vertex, initially false. To mark a vertex, set this flag to true. –Maintain a separate set of vertices, initially empty. To mark a vertex, add it to this set.

14-38 Depth-first traversal (1)  Depth-first traversal will traverse one possible path as far as possible, before traversing any alternative paths.  Illustration (starting from London): London Manchester Birmingham Bristol Swansea Liverpool Leeds Rugby Dublin Belfast Liverpool √ Possible order of visits: √ London √ Bristol √ Swansea √ Birmingham √ Manchester √ Leeds √ Rugby

14-39 Depth-first traversal (2)  Depth-first graph traversal algorithm: To traverse graph g in depth-first order, starting at vertex start: 1.Make vertex-stack contain only vertex start, and mark start as reached. 2.While vertex-stack is not empty, repeat: 2.1.Remove the top element of vertex-stack into v. 2.2.Visit vertex v. 2.3.For each unreached successor w of vertex v, repeat: Add vertex w to vertex-stack, and mark w as reached. 3.Terminate.

14-40 Breadth-first traversal (1)  Breadth-first traversal will visit all successors of a vertex, before visiting any of their successors. It will traverse shorter paths before longer paths.  Illustration (starting from London): Liverpool √ Possible order of visits: √ London √ Bristol √ Swansea √ Birmingham √ Manchester √ Leeds √ Rugby London Manchester Birmingham Bristol Swansea Liverpool Leeds Rugby Dublin Belfast

14-41 Breadth-first traversal (2)  Breadth-first graph traversal algorithm: To traverse graph g in breadth-first order, starting at vertex start: 1.Make vertex-queue contain only vertex start, and mark start as reached. 2.While vertex-queue is not empty, repeat: 2.1.Remove the front element of vertex-queue into v. 2.2.Visit vertex v. 2.3.For each unreached successor w of vertex v, repeat: Add vertex w to vertex-queue, and mark w as reached. 3.Terminate.

14-42 Graph search (1)  A graph search problem entails finding a path between two given vertices. E.g.: –Is there a road route from Glasgow to Dublin? –What is the length of the shortest route from Glasgow to London?  Graph search algorithms are similar to graph traversal algorithms, except that they terminate as soon as a solution is found.

14-43 Graph search (2)  Depth-first search will explore one possible path as far as possible, before exploring any alternative paths.  Breadth-first search will explore shorter paths before longer paths.

14-44 Shortest path (1)  Problem: Given a road network, find the shortest path between place start and place dest.  Idea: –Use breadth-first search. –For each place p, let pred[p] be the predecessor of p on the shortest path so far found from start to p, and let dist[p] be the distance along that path. –Initialize each dist[p] to  (infinity). –Thereafter reduce dist[p] (and update pred[p]) whenever a shorter path to p is found.

14-45 Shortest path (2)  Shortest-path algorithm: To find the shortest path through a road network from place start to place dest: 1.Make places contain all places in the road network. 2.Set dist[start] to 0 and set pred[start] to none. 3.For each place p other than start: 3.1.Set dist[p] to  and set pred[p] to none. 4.…

14-46 Shortest path (3)  Shortest-path algorithm (continued): 4.While places is not empty, repeat: 4.1.Remove from places the place p with least dist[p]. 4.2.If p = dest: Terminate with the path «start, …, pred[pred[dest]], pred[dest], dest». 4.3.For each road connecting p and another place q, such that q is in places, repeat: Let d be dist[p] + (distance from p to q) If d < dist[q], set dist[q] to d and set pred[q] to p. 5.Terminate with no path. At this point, we have already found the shortest path to dest.

14-47 Shortest path (4)  Illustration – shortest path from Lo(ndon) to Le(eds): Lo Ma Bi Br Le Ru BiBrLeLoMaRuplaces none,  none,  none,  none,0none,  none,  {Bi,Br,Le,Lo,Ma,Ru} Lo,220Lo,190none,  none,0none,  Lo,150{Bi,Br,Le,Ma,Ru} Ru,210Lo,190Ru,320none,0none,  Lo,150{Bi,Le,Ma} Ru,210Lo,190Ru,320none,0Bi,340Lo,150{Le,Ma} Shortest path is «Lo, Ru, Le». Ru,210Lo,190Ru,320none,0none,  Lo,150{Bi,Br,Le,Ma} pred[Bi] dist[Bi]