Chapter 14 Graphs © 2006 Pearson Addison-Wesley. All rights reserved.

Slides:



Advertisements
Similar presentations
Review Binary Search Trees Operations on Binary Search Tree
Advertisements

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.
Graphs Chapter 20 Data Structures and Problem Solving with C++: Walls and Mirrors, Carrano and Henry, © 2013.
Chapter 8, Part I Graph Algorithms.
Liang, Introduction to Java Programming, Seventh Edition, (c) 2009 Pearson Education, Inc. All rights reserved Chapter 27 Graph Applications.
Graphs Chapter 30 Carrano, Data Structures and Abstractions with Java, Second Edition, (c) 2007 Pearson Education, Inc. All rights reserved X.
Introduction This chapter explores graphs and their applications in computer science This chapter explores graphs and their applications in computer science.
© 2006 Pearson Addison-Wesley. All rights reserved14 A-1 Chapter 14 excerpts Graphs (breadth-first-search)
Edited by Malak Abdullah Jordan University of Science and Technology Data Structures Using C++ 2E Chapter 12 Graphs.
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.
Graphs Chapter 30 Slides by Steve Armstrong LeTourneau University Longview, TX  2007,  Prentice Hall.
© 2006 Pearson Addison-Wesley. All rights reserved14 A-1 Chapter 14 Graphs.
Nyhoff, ADTs, Data Structures and Problem Solving with C++, Second Edition, © 2005 Pearson Education, Inc. All rights reserved Graphs.
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.
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 Chapter 20 Data Structures and Problem Solving with C++: Walls and Mirrors, Frank Carrano, © 2012.
Graph Implementations Chapter 29 Copyright ©2012 by Pearson Education, Inc. All rights reserved.
Graphs Chapter 28 Copyright ©2012 by Pearson Education, Inc. All rights reserved.
© 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,
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. 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.
Computer Science: A Structured Programming Approach Using C Graphs A graph is a collection of nodes, called vertices, and a collection of segments,
COSC 2007 Data Structures II Chapter 14 Graphs I.
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. Contents Terminology Graphs as ADTs Applications of Graphs.
Graphs Chapter 28 © 2015 Pearson Education, Inc., Upper Saddle River, NJ. All rights reserved. Data Structures and Abstractions with Java, 4e Frank Carrano.
Chapter 20: Graphs. Objectives In this chapter, you will: – Learn about graphs – Become familiar with the basic terminology of graph theory – Discover.
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.
Leda Demos By: Kelley Louie Credits: definitions from Algorithms Lectures and Discrete Mathematics with Algorithms by Albertson and Hutchinson graphics.
© 2006 Pearson Addison-Wesley. All rights reserved14 B-1 Chapter 14 (continued) Graphs.
Graphs Chapter 20.
CS212: Data Structures and Algorithms
Data Structures 13th Week
Graphs.
Csc 2720 Instructor: Zhuojun Duan
CS202 - Fundamental Structures of Computer Science II
CS120 Graphs.
CMSC 341 Lecture 21 Graphs (Introduction)
Comp 245 Data Structures Graphs.
Graph Operations And Representation
Graphs Chapter 13.
Graphs Chapter 11 Objectives Upon completion you will be able to:
Copyright ©2012 by Pearson Education, Inc. All rights reserved
Chapter 11 Graphs.
Graphs.
Instructor: Scott Kristjanson CMPT 125/125 SFU Burnaby, Fall 2013
Chapter 15 Graph Theory © 2008 Pearson Addison-Wesley.
Graphs Chapter 7 Visit for more Learning Resources.
Graph Implementation.
Graphs G = (V, E) V are the vertices; E are the edges.
GRAPHS G=<V,E> Adjacent vertices Undirected graph
Chapter 14 Graphs © 2011 Pearson Addison-Wesley. All rights reserved.
Copyright ©2012 by Pearson Education, Inc. All rights reserved
Chapter 14 Graphs © 2011 Pearson Addison-Wesley. All rights reserved.
INTRODUCTION A graph G=(V,E) consists of a finite non empty set of vertices V , and a finite set of edges E which connect pairs of vertices .
Presentation transcript:

Chapter 14 Graphs © 2006 Pearson Addison-Wesley. All rights reserved

Terminology G = {V, E} A graph G consists of two sets A subgraph A set V of vertices, or nodes A set E of edges A subgraph Consists of a subset of a graph’s vertices and a subset of its edges Adjacent vertices Two vertices that are joined by an edge © 2006 Pearson Addison-Wesley. All rights reserved

Terminology Figure 14-2 a) A campus map as a graph; b) a subgraph © 2006 Pearson Addison-Wesley. All rights reserved

Terminology A path between two vertices A simple path A cycle A sequence of edges that begins at one vertex and ends at another vertex May pass through the same vertex more than once A simple path A path that passes through a vertex only once A cycle A path that begins and ends at the same vertex A simple cycle A cycle that does not pass through a vertex more than once © 2006 Pearson Addison-Wesley. All rights reserved

Terminology A connected graph A disconnected graph A complete graph A graph that has a path between each pair of distinct vertices A disconnected graph A graph that has at least one pair of vertices without a path between them A complete graph A graph that has an edge between each pair of distinct vertices © 2006 Pearson Addison-Wesley. All rights reserved

Terminology Figure 14-3 Graphs that are a) connected; b) disconnected; and c) complete © 2006 Pearson Addison-Wesley. All rights reserved

Terminology Multigraph Not a graph Allows multiple edges between vertices Figure 14-4 a) A multigraph is not a graph; b) a self edge is not allowed in a graph © 2006 Pearson Addison-Wesley. All rights reserved

Terminology Weighted graph A graph whose edges have numeric labels Figure 14-5a a) A weighted graph © 2006 Pearson Addison-Wesley. All rights reserved

Terminology Undirected graph Directed graph, or diagraph Edges do not indicate a direction Directed graph, or diagraph Each edge is a directed edge Figure 14-5b b) A directed graph © 2006 Pearson Addison-Wesley. All rights reserved

Terminology Directed graph Can have two edges between a pair of vertices, one in each direction Directed path A sequence of directed edges between two vertices Vertex y is adjacent to vertex x if There is a directed edge from x to y © 2006 Pearson Addison-Wesley. All rights reserved

Graphs As ADTs Graphs can be used as abstract data types Two options for defining graphs Vertices contain values Vertices do not contain values Operations of the ADT graph Create an empty graph Determine whether a graph is empty Determine the number of vertices in a graph Determine the number of edges in a graph © 2006 Pearson Addison-Wesley. All rights reserved

Graphs As ADTs Operations of the ADT graph (Continued) Determine whether an edge exists between two given vertices; for weighted graphs, return weight value Insert a vertex in a graph whose vertices have distinct search keys that differ from the new vertex’s search key Insert an edge between two given vertices in a graph Delete a particular vertex from a graph and any edges between the vertex and other vertices Delete the edge between two given vertices in a graph Retrieve from a graph the vertex that contains a given search key © 2006 Pearson Addison-Wesley. All rights reserved

Implementing Graphs Most common implementations of a graph Adjacency matrix Adjacency list Adjacency matrix for a graph with n vertices numbered 0, 1, …, n – 1 An n by n array matrix such that matrix[i][j] is 1 (or true) if there is an edge from vertex i to vertex j 0 (or false) if there is no edge from vertex i to vertex j © 2006 Pearson Addison-Wesley. All rights reserved

Implementing Graphs Figure 14-6 a) A directed graph and b) its adjacency matrix © 2006 Pearson Addison-Wesley. All rights reserved

Implementing Graphs Adjacency matrix for a weighted graph with n vertices numbered 0, 1, …, n – 1 An n by n array matrix such that matrix[i][j] is The weight that labels the edge from vertex i to vertex j if there is an edge from i to j  if there is no edge from vertex i to vertex j Figure 14-7 a) A weighted undirected graph and b) its adjacency matrix © 2006 Pearson Addison-Wesley. All rights reserved

Implementing Graphs Adjacency list An adjacency list for a graph with n vertices numbered 0, 1, …, n – 1 Consists of n linked lists The ith linked list has a node for vertex j if and only if the graph contains an edge from vertex i to vertex j This node can contain either Vertex j’s value, if any An indication of vertex j’s identity © 2006 Pearson Addison-Wesley. All rights reserved

Implementing Graphs Figure 14-8 a) A directed graph and b) its adjacency list © 2006 Pearson Addison-Wesley. All rights reserved

Implementing Graphs Adjacency list for an undirected graph Treats each edge as if it were two directed edges in opposite directions Figure 14-9 a) A weighted undirected graph and b) its adjacency list © 2006 Pearson Addison-Wesley. All rights reserved

Implementing Graphs Adjacency matrix compared with adjacency list Two common operations on graphs Determine whether there is an edge from vertex i to vertex j Find all vertices adjacent to a given vertex i Adjacency matrix Supports operation 1 more efficiently Adjacency list Supports operation 2 more efficiently Often requires less space than an adjacency matrix © 2006 Pearson Addison-Wesley. All rights reserved

Implementing a Graph Class Using the JCF ADT graph not part of JCF Can implement a graph using an adjacency list consisting of a vector of maps Implementation presented uses TreeSet class © 2006 Pearson Addison-Wesley. All rights reserved

Graph Traversals A graph-traversal algorithm Visits all the vertices that it can reach Visits all vertices of the graph if and only if the graph is connected A connected component The subset of vertices visited during a traversal that begins at a given vertex Can loop indefinitely if a graph contains a loop To prevent this, the algorithm must Mark each vertex during a visit, and Never visit a vertex more than once © 2006 Pearson Addison-Wesley. All rights reserved

Graph Traversals Figure 14-10 Visitation order for a) a depth-first search; b) a breadth-first search © 2006 Pearson Addison-Wesley. All rights reserved

Please open file carrano_ppt14_B.ppt to continue viewing chapter 14. © 2006 Pearson Addison-Wesley. All rights reserved