29.06.2013 Views

Curs 8 - Drumuri de cost minim [pdf] - Andrei

Curs 8 - Drumuri de cost minim [pdf] - Andrei

Curs 8 - Drumuri de cost minim [pdf] - Andrei

SHOW MORE
SHOW LESS

You also want an ePaper? Increase the reach of your titles

YUMPU automatically turns print PDFs into web optimized ePapers that Google loves.

Corectitudine (III)<br />

Teorema. G = (V,E), w:E->ℜ funcție <strong>de</strong> <strong>cost</strong><br />

asociată. Algoritmul BellmanFord aplicat acestui graf<br />

plecând din sursa s nu returnează EROARE dacă G<br />

nu conține cicluri negative, iar la terminare d[v] =<br />

δ(s,v) pentru ∀v∈V. Dacă G conține cel puțin un<br />

ciclu negativ accesibil din s, atunci algoritmul<br />

întoarce EROARE.<br />

Dem: pe baza lemei anterioare.<br />

Dacă ciclu negativ:<br />

d[v] = δ(s δ(s,v) v) ∀v∈R(s)<br />

d[v] = δ(s,v) = ∞, ∀v∉R(s) (inițializare)<br />

d[v] ≤ d[u] + w(u,v) nu se întoarce eroare<br />

Dacă ciclu negativ in cei |V|-1 pasi se scad <strong>cost</strong>urile<br />

muchiilor, iar in final ciclul se menține Eroare<br />

Proiectarea Algoritmilor 2010<br />

Optimizări Bellman-Ford<br />

Observație!<br />

Dacă d[v] nu se modifică la pasul i atunci nu<br />

trebuie sa relaxăm niciuna din muchiile care<br />

pleacă din v la pasul i + 1.<br />

=> păstrăm o coadă cu vârfurile modificate<br />

(o singură copie).<br />

Proiectarea Algoritmilor 2010<br />

5/8/2010<br />

8

Hooray! Your file is uploaded and ready to be published.

Saved successfully!

Ooh no, something went wrong!