文章目錄
  1. 1. Relaxation
  2. 2. Dijkstra Algorithm
    1. 2.1. Running time
    2. 2.2. Limitation
  3. 3. Bellman-Ford Algorithm
    1. 3.1. Running time analysis

Relaxation

Each point has a known distance so far, if a vertex + distance to a particular point is shorter than the known distance of the point, update it.
if (d[v] > d[u] + w(u, v))
d[v] = d[u] + w(u, v)

Dijkstra Algorithm

Extract min from the priority queue and relax its surroudning vertexes.

The priority queue is implement with Fibonacci heap

  Initialize-single-source(G, S) // set all distance to infinity
  S = {} // path 
  Q = G.V
  while (Q is not empty)
    u = EXTRACT-MIN(Q)
    S union u
    for each vertex v in adj[u] // total E times
      RELAX(u, v, w)

Running time

while loop executes V times
EXTRACT-MIN take O(log V)
decrease key operation O(1) with total edges E times

Overall Running time: O(V log V + E)

Naive method: O(V^2 + E), (linear search for EXTRACT-MIN)

Limitation

Only applicable for graphs with positive edge

Bellman-Ford Algorithm

Suppose a path from source to destination at most contains V - 1 edges
It basically try to relax every edges in the path until you reach the destination
It is based on dynamic proramming, but without a successor table of each vertex.
d[i, v] = d[i - 1, v]
d[i, v] = min(d[i, v], min(i - 1, u) + w(u, v))

for i = 1 to V - 1
  for each vertex u 
  if (d[u] is updated)
    for each vertex v in adj[u]
       if (d[v] > d[u] + w(u, v))
          d[v] = d[u] + w(u, v)
          successor = u
  if no value is change, break

It can also detect negative cycle

  for each edge(u, v)
    if (d[u] + w(u, v) < d[v])
       "negative cycle detected !!"

Running time analysis

Simply O(VE), memory space (V + E)

文章評論

文章目錄
  1. 1. Relaxation
  2. 2. Dijkstra Algorithm
    1. 2.1. Running time
    2. 2.2. Limitation
  3. 3. Bellman-Ford Algorithm
    1. 3.1. Running time analysis