How do I prove the correctness of this algorithm

212 Views Asked by At

We are given the following algorithm:

Input: bipartite graph G=(L,R,E), weight function w:E->Z and a source vertex s in L

Algorithm:
1) Define E1={(u,v) in E | u in L, v in R} and E2=E\E1
2) Initialize d(s)=0 and d(v)=inf for all vertices in L and R (except s)
3) Perform floor((|L|+|R|)/2) times:
  a. Pass on all edges (u,v) in E1:
    if d(v) > d(u) + w(u,v) then d(v) = d(u) + w(u,v)
  b. Pass on all edges (u,v) in E2:
    if d(v) > d(u) + w(u,v) then d(v) = d(u) + w(u,v)
4) Return d(v) for each vertex

This algorithm gives the shortest path from s to all other vertices and we are asked to prove its correctness. Now, as much as I can tell, the correctness proof should be exactly like Bellman-Ford's algorithm (using induction over the path's length), but I can't tell what is the change I am suppose to do in order to make it work for this algorithm.

I am not sure if I can ask question like these on here, but I've been on this for the past 4 days and I can't seem to see any difference from bellman-ford's correctness proof.

Any suggestions?
Thank you :)

0

There are 0 best solutions below