Directed and non-directed graphs
Directed
Graph is strongly connected if there is a path fro any vertex to any other vertex
directed
indegree = # ingoing edges
outdegree = # outgoing edges
sum are equal
non-directed
Graph is connected if there is a path between any two vertices
non-directed
Degree of v is # neighbors
sum of degree = 2 * #edges
adjacency lists
adjacency matrix
BFS
Input
Graph G given by AL
vertex v in G
Output
Array dist[1,n]
, where dist[u]
is the length of the shortest path from v
to u
function BTS(v;;G[1..n])
dist[1..n] filled with inf
dist[v] = 0
queue Q empty
push v to Q
while Q not empty
u = Q.pop()
for w in G[u]
if dist[w] = inf
dist[w] = dist[u] + 1
push w to Q
return dist
can also be done by DP
data:image/s3,"s3://crabby-images/8c563/8c563c0d2cca074791d82edc78aad7c5e69dede4" alt=""
data:image/s3,"s3://crabby-images/bf486/bf486867ef396a6fe42642c58be6786ed9d80030" alt=""
data:image/s3,"s3://crabby-images/5a3cc/5a3cc92df224e1a6ffa75ad2f28ca9e25cb92185" alt=""
data:image/s3,"s3://crabby-images/042e2/042e260536d43784e229bedb6fa104e902d7df8f" alt=""
data:image/s3,"s3://crabby-images/9ca46/9ca46e691ff2e58e2e9c65d0e467da2523c8f5be" alt=""
data:image/s3,"s3://crabby-images/32b08/32b08f1465d3a80502addc13dbf4a32477698f35" alt=""
网友评论