Graphs Flashcards
What is a graph?
It’s an abstraction to represent connectivity between objects Formally an undirected graph G it a collection of vertices V and edges E between pairs of them.
What is a loop in a graph? What is a simple graph?
It’s a path which connects a vertex to itself. A simple graph is a graph with no loops.
Describe ways to represent graphs in computer and compare their performance
- Edge list 2. Adjacency matrix 3. Adjacency list
data:image/s3,"s3://crabby-images/51752/51752456cf4472463ebea1d9bf1cbc3fecc668b5" alt=""
Let’s say we have a graph G and a vertice s. How to find all vertices v in G such that there is a path from s to v?
data:image/s3,"s3://crabby-images/de7e5/de7e5fba9002995f878121cba57d0f872fc1c926" alt=""
What is an idea of DFS? Runtime?
O(|E|) + O(|V|)
Each vertex is marked as visited exactly once - O(1) work per vertex
Each vertex checks each neighbour and total number of neighbours in O(|E|)
data:image/s3,"s3://crabby-images/cbc85/cbc85b563c819ba517768daccbab8010c7621bc5" alt=""
What is a connected component in an undirected graph?
It’s a set of vertices of a G, such that v is reachable from w if and only if they are in a same connected component.
How to find connected components in an undirected graph?
Use the modification of DFS with markers for connected components
data:image/s3,"s3://crabby-images/9598e/9598e3c5d50d68e6f245c7616cb087ca5155e739" alt=""
What is a DAG?
A directed acyclic graph is a directed graph G without cycles.
What directed graphs can be linearly ordered?
Any DAG can be linearly ordered. A graph with a cycle can not be.
What are strongly connected components in a DAG?
The vertices v and w in a DAG G are connected if you can reach v from w and w from v. A DAG can be partitioned into strongly connected components where two vertices are connected iff they are in the same cmponents
What is a metagraph? What properties it has?
It’s a graph describing connectivity between strongly connected coponents. A metagraph is a always a DAG.
data:image/s3,"s3://crabby-images/5515c/5515c47b2fc0ae84bfd6ac6295d4493e80a33c9b" alt=""
What are sources/sinks?
A source is a vertex with no incoming edges, and a sink is a vertex with no outgoing edges.
How to do a topological sort of a DAG?
- DFS(G)
- sort vertices by reverse post-order
How to compute strongly connected components of a DAG?
data:image/s3,"s3://crabby-images/02687/02687ac66c47092d6a75f86e6ea5d077a749ebb8" alt=""
What is the idea behind computig strongly connected components?
Idea: If v is in a sink SCC, explore(v) nds vertices reachable from v. This is exactly the SCC of v.
The vertex with the largest postorder number is in a source component!
Find sink components of G by running DFS on G R
Don’t need to rerun DFS on G R . Largest remaining post number comes from sink component.
Runtime O(|V | + |E|)
What are main ideas of Dijkstra’s algorithm?
data:image/s3,"s3://crabby-images/86c53/86c53afe8cfce6fe7e21cf17da83181c54bd93ca" alt=""