Concepts of Computation

Slides:



Advertisements
Similar presentations
Walks, Paths and Circuits Walks, Paths and Circuits Sanjay Jain, Lecturer, School of Computing.
Advertisements

Graph Algorithms: Minimum Spanning Tree We are given a weighted, undirected graph G = (V, E), with weight function w:
What is the first line of the proof? a). Assume G has an Eulerian circuit. b). Assume every vertex has even degree. c). Let v be any vertex in G. d). Let.
Representing Graphs Wade Trappe. Lecture Overview Introduction Some Terminology –Paths Adjacency Matrix.
4/17/2017 Section 8.5 Euler & Hamilton Paths ch8.5.
GRAPH Learning Outcomes Students should be able to:
 Jim has six children.  Chris fights with Bob,Faye, and Eve all the time; Eve fights (besides with Chris) with Al and Di all the time; and Al and Bob.
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,
CSNB143 – Discrete Structure Topic 9 – Graph. Learning Outcomes Student should be able to identify graphs and its components. Students should know how.
CSE 326: Data Structures NP Completeness Ben Lerner Summer 2007.
CSE 421 Algorithms Richard Anderson Winter 2009 Lecture 5.
CS 261 – Nov. 17 Graph properties – Bipartiteness – Isomorphic to another graph – Pseudograph, multigraph, subgraph Path Cycle – Hamiltonian – Euler.
Grade 11 AP Mathematics Graph Theory Definition: A graph, G, is a set of vertices v(G) = {v 1, v 2, v 3, …, v n } and edges e(G) = {v i v j where 1 ≤ i,
1 Lecture 5 (part 2) Graphs II (a) Circuits; (b) Representation Reading: Epp Chp 11.2, 11.3
Graphs. Representations of graphs : undirected graph An undirected graph G have five vertices and seven edges An adjacency-list representation of G The.
MAT 110 Workshop Created by Michael Brown, Haden McDonald & Myra Bentley for use by the Center for Academic Support.
BCA-II Data Structure Using C Submitted By: Veenu Saini
Data Structures & Algorithm Analysis lec(8):Graph T. Souad alonazi
Data Structures and Algorithm Analysis Lecture 5
Graphs A New Data Structure
An Introduction to Graph Theory
Hamiltonian Graphs Graphs Hubert Chan (Chapter 9.5)
The NP class. NP-completeness
P & NP.
Combinatorial Counting
CSNB 143 Discrete Mathematical Structures
BackTracking CS255.
Graphs Representation, BFS, DFS
Applied Discrete Mathematics Week 13: Graphs
Special Graphs By: Sandeep Tuli Astt. Prof. CSE.
Proof technique (pigeonhole principle)
Graphs Hubert Chan (Chapter 9) [O1 Abstract Concepts]
Redraw these graphs so that none of the line intersect except at the vertices B C D E F G H.
Chapters 8.1 and 8.2 Based on slides by Y. Peng University of Maryland
Graph theory Definitions Trees, cycles, directed graphs.
Agenda Lecture Content: Introduction to Graph Path and Cycle
Hamiltonian Graphs Graphs Hubert Chan (Chapter 9.5)
EECS 203 Lecture 20 More Graphs.
Topological Sort (topological order)
CS120 Graphs.
Planarity Testing.
CSE 421: Introduction to Algorithms
ICS 353: Design and Analysis of Algorithms
Graph Theory.
Graphs Chapter 13.
Chapters 8.1 and 8.2 Based on slides by Y. Peng University of Maryland
Spanning Trees.
Lectures on Graph Algorithms: searching, testing and sorting
Graphs.
What is a Graph? a b c d e V= {a,b,c,d,e} E= {(a,b),(a,c),(a,d),
Discrete Math II Howon Kim
CSE 421: Introduction to Algorithms
Richard Anderson Autumn 2016 Lecture 5
Representing Graphs Wade Trappe.
Richard Anderson Winter 2009 Lecture 6
Chapter 15 Graph Theory © 2008 Pearson Addison-Wesley.
Proof Techniques.
Breadth-First Search L0 L1 L2 C B A E D F Breadth-First Search
Applied Combinatorics, 4th Ed. Alan Tucker
Hamilton Paths and Circuits
Richard Anderson Winter 2019 Lecture 6
Richard Anderson Lecture 5 Graph Theory
Richard Anderson Winter 2019 Lecture 5
Concepts of Computation
Concepts of Computation
Concepts of Computation
Prof. Ramin Zabih Graph Traversal Prof. Ramin Zabih
CS 173, Lecture B Tandy Warnow
Richard Anderson Autumn 2015 Lecture 6
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:

Concepts of Computation Session 9b Graph Algorithms Dr Oded Lachish Email: oded@dcs.bbk.ac.uk (Slides prepared with the support of Dr Paul Newman and Eva Szatmari)

Graph Algorithms Breadth First Search (BFS) Checking if a graph is bipartite Graph theoretic problems for general knowledge Hamilton path and cycle K-Clique

Graphs and computers How does a computer access a graph G=(V,E). One of the ways is: The computer has access to the set of vertices V={v1, v2,…, vn} ({v1, v2,…, vn} means vi for every i from 1 to n, where n is the size of the set V) The computer also has access to the set E in the following form: It can check for any vertex of its choice in V, what are the vertices adjacent to it. In the graph on the right the vertices v3, v5, v7 , v8 are adjacent to v4 Another way to say this is that v3, v5, v7 , v8 are neighbours of v4 v7 v2 v3 v1 v4 v6 v5 v8

Graphs and computers What can we do with what we learned in the previous slide We can get the computer to find the distance between v1 and v8 How? (remember the computer doesn’t see the graph like we do) Let V0 = {v1} Find all the neighbours of v0 and put them in a set V1. (V1 = {v2, v6}) For every vertex in V1, find all its neighbours and if they are not in V0 ∪ V1, then add them to V2. (V2 = {v3, v5}) For every vertex in V2, find all its neighbours and if they are not in V0 ∪ V1 ∪ V2, then add them to V3. (V3 = {v4}) In the same way we get V4 = {v7, v8} and V5 = {} this means we are done. What next? v7 v2 v3 v1 v4 v6 v5 v8

Graphs and computers We got v1 v2 v3 v6 v5 v4 v7 v8 Graphs and computers We got V0 = {v1}, V1 = {v2, v6}, V2 = {v3, v5}, V3 = {v4}, V4 = {v7, v8} and V5 = {} This means that d(v1, v1) =0 V0 = {v1} d(v1, v2) = 1, d(v1, v6) = 1, V1 = {v2, v6} d(v1, v3) = 2, d(v1, v5) = 2 V2 = {v3, v5} d(v1, v4) = 3 V3 = {v4} d(v1, v7) = 4, d(v1, v8) = 4 V4 = {v7, v8} We got the answer to the question we asked and more. This algorithms is called Breadth First Search.

Breadth First Search (BFS) How do we do BFS in general: Pick a vertex of our choice and put it in V0 Set i to 0 do If Vi is empty stop If Vi is not empty, then for every vertex in Vi, find all its neighbours and if they are not in a set Vj such that j ≤i and add them to Vi+1. Increase i by 1 Repeat step 3 The sets the computer found tell the distance from the vertex you picked to every other vertex in the graph!

Bipartite graphs Recall, in a bipartite graph G, the vertex set V is partitioned into two subsets (say S and T ) What if someone tells us a graph is bipartite but does not provide us with the sets? Is the following graphs bipartite? v7 v1 v4 v3 v2 v6 v8 v5

Finding sets for a Bipartite graph Is the following graphs bipartite? We can take the BFS and change it to get an algorithm that solvers th problem Pick a vertex of our choice and put it in V0 Set i to 0 and V1 to be the empty do If Vi is not empty, then for every vertex in Vi, find all its neighbours and add them to V1-i. If V1-i did not change, then stop if i is 1, then set it to 0, and if i is 0, then set it to 1 Repeat step 3 This works for graphs that are connected, if they aren’t It is done for every connected component separately. In the next slide we shall see how this work v7 v1 v4 v3 v2 v6 v8 v5

Checking if a graph is Bipartite V0 = {v3} The vertices adjacent to v3 are v1 , v2 and v8 so we add the to V1-0 = V1 and hence now V1 = {v1 , v2 , v8 } The vertices adjacent to the vertices in V1 are v3 , v4 , v5 and v7 and hence now V0 = {v3 , v4 , v5 , v7} The vertices adjacent to the vertices in V0 are v1 , v2 , v6 and v8 and hence now V1 = {v1 , v2 , v6 , v8} V0 hasn’t changed so we are done v7 v1 v4 v3 v2 v6 v8 v5

Checking if a graph is Bipartite v7 v1 Checking if a graph is Bipartite v4 v3 v2 The graph following graph is bipartite With sets {v1 , v2 , v6 , v8} and {v3 , v4 , v5 , v7} We can draw it in the manner we learned for bipartite graphs v6 v8 v5 v4 v1 v3 v2 v8 v7 v6 v5

What if the graph is not bipartite? If this happens, then for at least one of V0 and V1 there exists an edge between two of its vertices. So when we get the sets V0 and V1 from the algorithm we have to check this. If it happened then the graph is not bipartite. Is the another way to know that a graph is not bipartite?

All the closed walks in Bipartite graphs have an even length If we follow a walk on a bipartite graph then every edge moves us to the other side For example: {v1 , v4 , v2 , v3 , v1} So we go forth and back repeatedly until we return to where we started, each time we did that counts for 2 edges So the total length must be a multiple of 2 v1 v2 v3 v6 v5 v4 v7 v8

All the closed walks in Bipartite graphs have an even length Conclusion: a graph is bipartite if and only if all its closed walks have even length The graph below is not bipartite, because it has a cycle of length 3 (which is a closed walk of length 3) (v8 , v6 , v5) Note: obviously to check if a graph is bipartite you don’t need to check every closed walk (you can’t), Instead you use the algorithm we v7 v1 v4 v3 v2 v6 v8 v5 We got this graph by adding an edge to a graph from a previous example

A graph is bipartite if and only if all its closed walks have even length To check if a graph is bipartite you don’t need to check every closed walk (you can’t), Instead you use the algorithm The advantage of the closed walk with odd length is If someone provides you with a closed walk with an odd length, then in order to believe that the graph is not bipartite, you only need to check that this is indeed a walk, which a lot less than to run the algorithm we learned. v7 v1 v4 v3 v2 v6 v8 v5

Hamilton path, A Hamiltonian path is a path in which every vertex participates (recall that the fact that it is a path means that every vertex must participate exactly once. v9 v7 v2 v3 v1 v4 v6 v5 v8 (v1, v2, v3 , v9 , v7 , v8 , v4 , v5 , v6 ) – in the above example this is a Hamilton path A graph may have a number of different Hamilton Paths.

Hamilton path, cycle A Hamiltonian cycle is a cycle in which every vertex participates (recall that the fact that it is a cycle means that every vertex must participate exactly once, excluding the first). v9 v7 v2 v3 v1 v4 v6 v5 v8 (v1, v2, v3 , v9 , v7 , v8 , v4 , v5 , v6 , v1) – in the above example this is a Hamilton cycle A graph may have a number of different Hamilton Cycles.

Hamilton path and cycle The graph below has a Hamiltonian path but not a Hamiltonian Cycle v7 v2 v3 v1 v4 v6 v5 v8 Can you find the path? Can you explain why it does not have a cycle?

Hamilton path and cycle Answers v7 v2 v3 v1 v4 v6 v5 v8 The path is on the slide There is no cycle because, if it started at v1 it has to go through v4 on the way to v7 and then again on the way back to v1 If the there is a Hamiltonian cycle starting at any other vertex, then there is a Hamiltonian path starting at v1

Hamilton path, cycle How to solve a question about this in the exam: If asked you should be able to find it? The answer to why a graph doesn’t have a Hamiltonian Path or Cycle you should be able to give an explanation like we just gave (why a specific vertex must be used twice).

k-clique A clique is a complete subgraph. In the k-clique problem the goal is to find a subgraph H of a graph G, so that H has k vertices and is a complete graph. v7 v2 v3 v1 v4 v6 v5 v8 In the graph above the induced subgraph with vertex set {v2, v3, v5, v6 } Is a clique of size 4 since it has all the possible edges. So, the graph in the example has a 4-clique!

k-clique v7 v2 v3 v1 v4 v6 v5 v8 In the graph above the induced subgraph with vertex set {v2, v3, v5, v6 } Is a clique of size 4 since it has all the possible edges. So, the graph in the example has a 4-clique! Does the graph have a 5-clique? No, In a 5-clique every vertex has degree 4, so a graph that has a 5-clique must have at least 5 vertices of degree 4. The graph above has 5 vertices with degree 4 {v2, v3, v5, v6 , v4 } , but they don’t form a clique, because there is no edge including v6 and v4 , so it does not have a 5-clique!

k-clique v7 v2 v3 v1 v4 v11 v6 v5 v8 Does having 5 vertices with degree 4 mean that the graph has a 5-clique? No, The graph in the above example has 9 vertices with degree at least 4, but does not have a 5-clique. Is there an easy way to find a k-clique? Probably not, we don’t know one. Currently, the best we can do is running time that is not far better than nk. This is bad, if n=50 and k=20, the number is already too big.

k-clique How to solve a question about this in the exam: If asked you should be able to find it? The answer to why a graph doesn’t have a clique of size more than say 4 is based on the degree explanation we just gave.