Undirected Graphs Flashcards

1
Q

What is the input format used for all API’s?

A
  • Num vertex
  • Num edge
  • E pairs of values between 0 and v -1
How well did you know this?
1
Not at all
2
3
4
5
Perfectly
2
Q

What are the two basic requirements for representation?

A
  • Space to accomodate
  • Time-efficient
How well did you know this?
1
Not at all
2
3
4
5
Perfectly
3
Q

What are the 3 data structures we can use for graphs, and what are their caviates?

A
  • Adjacency matrix V x V Boolean with A{vw} = true if adjacent edge. Space cost V^2
  • Array of edges using Edge class. adj() implementation would involve examining all edges - time constraint
  • Adjacency list - Vertex-indexed array of lists of the vertices adjacent to each vertex, using bags.
How well did you know this?
1
Not at all
2
3
4
5
Perfectly
4
Q

What is the worst case time to mark vertices connected to given source?

A

proportional to sum of degrees

How well did you know this?
1
Not at all
2
3
4
5
Perfectly
5
Q

How do we search an undirected graph using DFS and what do we use to explore multiple edges?

A
  1. First unmarked vertex in current vertex’s adjacency list. Call recursive and mark vertex.
  2. First vertex will be first in newly marked vertex’s adjacency list, so skip.
  3. Continue forwards until vertex has all edges marked. Once reached, return to previous until unmarked edge present.
  4. Once everything checked, dfs() checks vertices on list then the other remaining lists, however all have been marked.

Use stack

How well did you know this?
1
Not at all
2
3
4
5
Perfectly
6
Q

What is the difference between BFS and DFS?

A

Taking next vertex from data structure.
* Least recent for BFS
* Most recent for DFS

How well did you know this?
1
Not at all
2
3
4
5
Perfectly
7
Q

What is the time complexit in the worst case for BFS?

A

V + E

How well did you know this?
1
Not at all
2
3
4
5
Perfectly
8
Q

What is the product of the path finding for BFS?

A

An array edgeTo[], which is a parent-link representation of a tree rooted at s which defines shortest paths from s to every vertex connected to s

How well did you know this?
1
Not at all
2
3
4
5
Perfectly
9
Q

How does the path-finding in BFS work and what do we use to explore multiple edges?

A
  1. Put source vertex on queue
  2. Take next vertex v from queue and mark it
  3. Put onto the queue all unmarked vertices that are adjacent to v
  4. Continue 2, 3 until queue empty

We use a queue

How well did you know this?
1
Not at all
2
3
4
5
Perfectly
10
Q

What is a single source path?

A

Given graph and source vertex, is there a path from s to a given target vertex v? If yes, find path.

How well did you know this?
1
Not at all
2
3
4
5
Perfectly
11
Q

What is the purpose of the edgeTo[] array in finding paths?

A

Integer values that give way to find path back to s for each vertex connected to s.
Remember edge v-w that takes us to each vertex w for the first time, setting edgeTo[w] = v

How well did you know this?
1
Not at all
2
3
4
5
Perfectly