Graphs What are Graphs? General meaning in everyday math: A plot or chart of numerical data using a coordinate system. Technical meaning in discrete.

Slides:



Advertisements
Similar presentations
CSE 211 Discrete Mathematics
Advertisements

Chapter 9 Graphs.
Lecture 5 Graph Theory. Graphs Graphs are the most useful model with computer science such as logical design, formal languages, communication network,
22C:19 Discrete Math Graphs Fall 2010 Sukumar Ghosh.
Midwestern State University Department of Computer Science Dr. Ranette Halverson CMPS 2433 – CHAPTER 4 GRAPHS 1.
1 Slides based on those of Kenneth H. Rosen Slides by Sylvia Sorkin, Community College of Baltimore County - Essex Campus Graphs.
Applied Discrete Mathematics Week 12: Trees
1 Section 8.2 Graph Terminology. 2 Terms related to undirected graphs Adjacent: 2 vertices u & v in an undirected graph G are adjacent (neighbors) in.
SE561 Math Foundations Week 11 Graphs I
Graph Theory in CS Route Search in Online Map Services
Selected Topics in Data Networking Graph Representation.
Applied Discrete Mathematics Week 12: Trees
Graphs.
KNURE, Software department, Ph , N.V. Bilous Faculty of computer sciences Software department, KNURE Discrete.
Discrete Mathematics Lecture 9 Alexander Bukharovich New York University.
Let us switch to a new topic:
22C:19 Discrete Math Graphs Spring 2014 Sukumar Ghosh.
9.2 Graph Terminology and Special Types Graphs
GRAPH Learning Outcomes Students should be able to:
Graphs Chapter 10.
Graph Theoretic Concepts. What is a graph? A set of vertices (or nodes) linked by edges Mathematically, we often write G = (V,E)  V: set of vertices,
1 Graphs Chapters 9.1 and 9.2 University of Maryland Chapters 9.1 and 9.2 Based on slides by Y. Peng University of Maryland.
Graph Theory 4/23/2017.
16.1 CompSci 102© Michael Frank Today’s topics GraphsGraphs –Basics & types –Properties –Connectivity –Hamilton & Euler Paths Reading: Sections Reading:
Module #19: Graph Theory: part I Rosen 5 th ed., chs. 8-9 내년 3 월 ? 교환 학생 프로그램 영어 점수 미리미리 준비하세요.
1 Elements of Graph Theory Quick review of Chapters 9.1… 9.5, 9.7 (studied in Mt1348/2008) = all basic concepts must be known New topics we will mostly.
Lecture 10: Graphs Graph Terminology Special Types of Graphs
© by Kenneth H. Rosen, Discrete Mathematics & its Applications, Sixth Edition, Mc Graw-Hill, 2007 Chapter 9 (Part 2): Graphs  Graph Terminology (9.2)
1 CS104 : Discrete Structures Chapter V Graph Theory.
Based on slides by Y. Peng University of Maryland
9.1 Introduction to Graphs
Module #19: Graph Theory: part II Rosen 5 th ed., chs. 8-9.
GRAPHS THEROY. 2 –Graphs Graph basics and definitions Vertices/nodes, edges, adjacency, incidence Degree, in-degree, out-degree Subgraphs, unions, isomorphism.
Based on Rosen, Discrete Mathematics & Its Applications, 5e Prepared by (c) Michael P. Frank Modified by (c) Haluk Bingöl 1/18 Module.
Graphs.  Definition A simple graph G= (V, E) consists of vertices, V, a nonempty set of vertices, and E, a set of unordered pairs of distinct elements.
Week 11 - Monday.  What did we talk about last time?  Binomial theorem and Pascal's triangle  Conditional probability  Bayes’ theorem.
Discrete Structures Graphs 1 (Ch. 10) Dr. Muhammad Humayoun Assistant Professor COMSATS Institute of Computer Science, Lahore.
1 12/2/2015 MATH 224 – Discrete Mathematics Formally a graph is just a collection of unordered or ordered pairs, where for example, if {a,b} G if a, b.
September1999 CMSC 203 / 0201 Fall 2002 Week #13 – 18/20/22 November 2002 Prof. Marie desJardins.
Chapter 5 Graphs  the puzzle of the seven bridge in the Königsberg,  on the Pregel.
1 Graphs Theory UNIT IV. 2Contents  Basic terminology,  Multi graphs and weighted graphs  Paths and circuits  Shortest path in weighted graph  Hamiltonian.
Graph Theory and Applications
Graphs 9.1 Graphs and Graph Models أ. زينب آل كاظم 1.
Graph theory and networks. Basic definitions  A graph consists of points called vertices (or nodes) and lines called edges (or arcs). Each edge joins.
And before you really hate (mathematical) relations and begin to break your (social) relations, let’s switch to a new topic: Graphs Discrete Structures.
Discrete Structures CISC 2315 FALL 2010 Graphs & Trees.
LOGO.  Relations:  In these slides: Introductions to graphs Graph terminology Representing graphs and graph isomorphism Connectivity Euler and Hamilton.
Chapter 9: Graphs.
Introduction to Graph Theory By: Arun Kumar (Asst. Professor) (Asst. Professor)
Graphs Rosen, Chapter 8. NOT ONE OF THESE! One of these!
Chap 7 Graph Def 1: Simple graph G=(V,E) V : nonempty set of vertices E : set of unordered pairs of distinct elements of V called edges Def 2: Multigraph.
1 GRAPH Learning Outcomes Students should be able to: Explain basic terminology of a graph Identify Euler and Hamiltonian cycle Represent graphs using.
1 Lecture 5 (part 2) Graphs II (a) Circuits; (b) Representation Reading: Epp Chp 11.2, 11.3
GRAPH THEORY Discrete Math Team KS MATEMATIKA DISKRIT (DISCRETE MATHEMATICS )
رياضيات متقطعة لعلوم الحاسب MATH 226. Chapter 10.
1 Graphs Chapters 10.1 and 10.2 University of Maryland Chapters 10.1 and 10.2 Based on slides by Y. Peng University of Maryland.
Chapter Chapter Summary Graphs and Graph Models Graph Terminology and Special Types of Graphs Representing Graphs and Graph Isomorphism Connectivity.
An Introduction to Graph Theory
Graphs: Definitions and Basic Properties
Graphs Hubert Chan (Chapter 9) [O1 Abstract Concepts]
COT 3100, Spring 2001 Applications of Discrete Structures
Graphs Rosen, Chapter 8.
Graph theory Definitions Trees, cycles, directed graphs.
Taibah University College of Computer Science & Engineering Course Title: Discrete Mathematics Code: CS 103 Chapter 10 Graphs Slides are adopted from “Discrete.
Rosen 5th ed., chs. 8-9 ~44 slides (more later), ~3 lectures
Graph & Trees Chapters 10-11
CS100: Discrete structures
Rosen 5th ed., ch. 8.1~8.5 ~44 slides (more later), ~3 lectures
Applied Discrete Mathematics Week 13: Graphs
Concepts of Computation
Presentation transcript:

Graphs

What are Graphs? General meaning in everyday math: A plot or chart of numerical data using a coordinate system. Technical meaning in discrete mathematics: A particular class of discrete structures (to be defined) that is useful for representing relations and has a convenient webby- looking graphical representation. Not

Applications of Graphs Potentially anything (graphs can represent relations, relations can describe the extension of any predicate). Apps in networking, scheduling, flow optimization, circuit design, path planning. More apps: Geneology analysis, computer game-playing, program compilation, object- oriented design, …

Terminology A simple graph G = (V,E) consists of V, a nonempty set of vertices, and E, as set of unordered pairs of distinct elements of V called edges. A multigraph G = (V,E) consists of a set V of vertices, a set E of edges, and a function f from E to {{u,v} | u,v  V, u ≠I v}. The edges e1 and e2 are called multiple or parallel edges if f(e 1 ) = f(e 2 ).

Simple Graphs Correspond to symmetric, irreflexive binary relations R. A simple graph G=(V,E) consists of: – a set V of vertices or nodes (V corresponds to the universe of the relation R), – a set E of edges / arcs / links: unordered pairs of [distinct] elements u,v  V, such that uRv. Visual Representation of a Simple Graph

Let V be the set of states in the far- southeastern U.S.: – I.e., V={FL, GA, AL, MS, LA, SC, TN, NC} Let E={{u,v}|u adjoins v} ={{FL,GA},{FL,AL},{FL,MS}, {FL,LA},{GA,AL},{AL,MS}, {MS,LA},{GA,SC},{GA,TN}, {SC,NC},{NC,TN},{MS,TN}, {MS,AL}} Example of a Simple Graph TN AL MS LA SC GA FL NC

Multigraphs Like simple graphs, but there may be more than one edge connecting two given nodes. A multigraph G=(V, E, f ) consists of a set V of vertices, a set E of edges (as primitive objects), and a function f:E  {{u,v}|u,v  V  u  v}. E.g., nodes are cities, edges are segments of major highways. Parallel edges

Pseudographs Like a multigraph, but edges connecting a node to itself are allowed. (R may be reflexive.) A pseudograph G=(V, E, f ) where f:E  {{u,v}|u,v  V}. Edge e  E is a loop if f(e)={u,u}={u}. E.g., nodes are campsites in a state park, edges are hiking trails through the woods.

Directed Graphs Correspond to arbitrary binary relations R, which need not be symmetric. A directed graph (V,E) consists of a set of vertices V and a binary relation E on V. E.g.: V = set of People, E={(x,y) | x loves y}

Directed Multigraphs Like directed graphs, but there may be more than one arc from a node to another. A directed multigraph G=(V, E, f ) consists of a set V of vertices, a set E of edges, and a function f:E  V  V. E.g., V=web pages, E=hyperlinks. The WWW is a directed multigraph...

Types of Graphs: Summary Summary of the book’s definitions. Keep in mind this terminology is not fully standardized across different authors...

§8.2: Graph Terminology You need to learn the following terms: Adjacent, connects, endpoints, degree, initial, terminal, in-degree, out-degree, complete, cycles, wheels, n-cubes, bipartite, subgraph, union.

Adjacency Let G be an undirected graph with edge set E. Let e  E be (or map to) the pair {u,v}. Then we say: u, v are adjacent / neighbors / connected. Edge e is incident with vertices u and v. Edge e connects u and v. Vertices u and v are endpoints of edge e.

Degree of a Vertex Let G be an undirected graph, v  V a vertex. The degree of v, deg(v), is its number of incident edges. (Except that any self-loops are counted twice.) A vertex with degree 0 is called isolated. A vertex of degree 1 is called pendant.

Handshaking Theorem Let G be an undirected (simple, multi-, or pseudo-) graph with vertex set V and edge set E. Then Corollary: Any undirected graph has an even number of vertices of odd degree.

Directed Adjacency Let G be a directed (possibly multi-) graph, and let e be an edge of G that is (or maps to) (u,v). Then we say: – u is adjacent to v, v is adjacent from u – e comes from u, e goes to v. – e connects u to v, e goes from u to v – the initial vertex of e is u – the terminal vertex of e is v

Directed Degree Let G be a directed graph, v a vertex of G. – The in-degree of v, deg  (v), is the number of edges going to v. – The out-degree of v, deg  (v), is the number of edges coming from v. – The degree of v, deg(v):  deg  (v)+deg  (v), is the sum of v’s in-degree and out-degree.

Directed Handshaking Theorem Let G be a directed (possibly multi-) graph with vertex set V and edge set E. Then: Note that the degree of a node is unchanged by whether we consider its edges to be directed or undirected.

Special Graph Structures Special cases of undirected graph structures: Complete graphs K n Cycles C n Wheels W n n-Cubes Q n Bipartite graphs Complete bipartite graphs K m,n

Complete Graphs For any n  N, a complete graph on n vertices, K n, is a simple graph with n nodes in which every node is adjacent to every other node:  u,v  V: u  v  {u,v}  E. K1K1 K2K2 K3K3 K4K4 K5K5 K6K6 Note that K n has edges.

Cycles For any n  3, a cycle on n vertices, C n, is a simple graph where V={v 1,v 2,…,v n } and E={{v 1,v 2 },{v 2,v 3 },…,{v n  1,v n },{v n,v 1 }}. C3C3 C4C4 C5C5 C6C6 C7C7 C8C8 How many edges are there in C n ?

Wheels For any n  3, a wheel W n, is a simple graph obtained by taking the cycle C n and adding one extra vertex v hub and n extra edges {{v hub,v 1 }, {v hub,v 2 },…,{v hub,v n }}. W3W3 W4W4 W5W5 W6W6 W7W7 W8W8 How many edges are there in W n ?

n-cubes (hypercubes) For any n  N, the hypercube Q n is a simple graph consisting of two copies of Q n-1 connected together at corresponding nodes. Q 0 has 1 node. Q0Q0 Q1Q1 Q2Q2 Q3Q3 Q4Q4 Number of vertices: 2 n. Number of edges:Exercise to try!

Def’n.: A graph G=(V,E) is bipartite (two- part) iff V = V 1 ∩V 2 where V 1  V 2 =  and  e  E:  v 1  V 1,v 2  V 2 : e={v 1,v 2 }. In English: The graph can be divided into two parts in such a way that all edges go between the two parts. Bipartite Graphs V1V1 V2V2 This definition can easily be adapted for the case of multigraphs and directed graphs as well. Can represent with zero-one matrices.

Complete Bipartite Graphs For m,n  N, the complete bipartite graph K m,n is a bipartite graph where |V 1 | = m, |V 2 | = n, and E = {{v 1,v 2 }|v 1  V 1  v 2  V 2 }. – That is, there are m nodes in the left part, n nodes in the right part, and every node in the left part is connected to every node in the right part. K 4,3 K m,n has _____ nodes and _____ edges.

Subgraphs A subgraph of a graph G=(V,E) is a graph H=(W,F) where W  V and F  E. G H

Graph Unions The union G 1  G 2 of two simple graphs G 1 =(V 1, E 1 ) and G 2 =(V 2,E 2 ) is the simple graph (V 1  V 2, E 1  E 2 ). a bc d e a bc d f 

§8.3: Graph Representations & Isomorphism Graph representations: – Adjacency lists. – Adjacency matrices. – Incidence matrices. Graph isomorphism: – Two graphs are isomorphic iff they are identical except for their node names.

Adjacency Lists A table with 1 row per vertex, listing its adjacent vertices. a b d c f e

Directed Adjacency Lists 1 row per node, listing the terminal nodes of each edge incident from that node.

Adjacency Matrices A way to represent simple graphs – possibly with self-loops. Matrix A=[a ij ], where a ij is 1 if {v i, v j } is an edge of G, and is 0 otherwise. Can extend to pseudographs by letting each matrix elements be the number of links (possibly >1) between the nodes.

Graph Isomorphism Formal definition: – Simple graphs G 1 =(V 1, E 1 ) and G 2 =(V 2, E 2 ) are isomorphic iff  a bijection f:V 1  V 2 such that  a,b  V 1, a and b are adjacent in G 1 iff f(a) and f(b) are adjacent in G 2. – f is the “renaming” function between the two node sets that makes the two graphs identical. – This definition can easily be extended to other types of graphs.

Graph Invariants under Isomorphism Necessary but not sufficient conditions for G 1 =(V 1, E 1 ) to be isomorphic to G 2 =(V 2, E 2 ): – We must have that |V1|=|V2|, and |E1|=|E2|. – The number of vertices with degree n is the same in both graphs. – For every proper subgraph g of one graph, there is a proper subgraph of the other graph that is isomorphic to g.

Isomorphism Example If isomorphic, label the 2nd graph to show the isomorphism, else identify difference. a b c d e f b d a e f c

Are These Isomorphic? If isomorphic, label the 2nd graph to show the isomorphism, else identify difference. a b c d e Same # of vertices Same # of edges Different # of verts of degree 2! (1 vs 3)

§8.4: Connectivity In an undirected graph, a path of length n from u to v is a sequence of adjacent edges going from vertex u to vertex v. A path is a circuit if u=v. A path traverses the vertices along it. A path is simple if it contains no edge more than once.

Paths in Directed Graphs Same as in undirected graphs, but the path must go in the direction of the arrows.

Connectedness An undirected graph is connected iff there is a path between every pair of distinct vertices in the graph. Theorem: There is a simple path between any pair of vertices in a connected undirected graph. Connected component: connected subgraph A cut vertex or cut edge separates 1 connected component into 2 if removed.

Directed Connectedness A directed graph is strongly connected iff there is a directed path from a to b for any two vertices a and b. It is weakly connected iff the underlying undirected graph (i.e., with edge directions removed) is connected. Note strongly implies weakly but not vice- versa.

Paths & Isomorphism Note that connectedness, and the existence of a circuit or simple circuit of length k are graph invariants with respect to isomorphism.

Counting Paths w Adjacency Matrices Let A be the adjacency matrix of graph G. The number of paths of length k from v i to v j is equal to (A k ) i,j. – The notation (M) i,j denotes m i,j where [m i,j ] = M.

§8.5: Euler & Hamilton Paths An Euler circuit in a graph G is a simple circuit containing every edge of G. An Euler path in G is a simple path containing every edge of G. A Hamilton circuit is a circuit that traverses each vertex in G exactly once. A Hamilton path is a path that traverses each vertex in G exactly once.

Bridges of Königsberg Problem Can we walk through town, crossing each bridge exactly once, and return to start? A B C D The original problem Equivalent multigraph

Euler Path Theorems Theorem: A connected multigraph has an Euler circuit iff each vertex has even degree. Theorem: A connected multigraph has an Euler path (but not an Euler circuit) iff it has exactly 2 vertices of odd degree. – One is the start, the other is the end.

Euler Circuit Algorithm Begin with any arbitrary node. Construct a simple path from it till you get back to start. Repeat for each remaining subgraph, splicing results back into original cycle.

Round-the-World Puzzle Can we traverse all the vertices of a dodecahedron, visiting each once?` Dodecahedron puzzle Equivalent graph Pegboard version

Hamiltonian Path Theorems Dirac’s theorem: If (but not only if) G is connected, simple, has n  3 vertices, and  v deg(v)  n/2, then G has a Hamilton circuit. – Ore’s corollary: If G is connected, simple, has n≥3 nodes, and deg(u)+deg(v)≥n for every pair u,v of non-adjacent nodes, then G has a Hamilton circuit.