Algoritmi e Strutture Dati

Slides:



Advertisements
Presentazioni simili
Algoritmi e Strutture Dati
Advertisements

Algoritmi e Strutture Dati
Algoritmi e Strutture Dati
Algoritmi e Strutture Dati
Algoritmi e Strutture Dati
Grafi Algoritmi e Strutture Dati. Camil Demetrescu, Irene Finocchi, Giuseppe F. Italiano Algoritmi e strutture dati 2/ed 2 Copyright © The McGraw.
Algoritmi e Strutture Dati
Algoritmi e Strutture Dati
Camil Demetrescu, Irene Finocchi, Giuseppe F. ItalianoAlgoritmi e strutture dati Copyright © The McGraw - Hill Companies, srl 1 Usa la tecnica del.
Camil Demetrescu, Irene Finocchi, Giuseppe F. ItalianoAlgoritmi e strutture dati Copyright © The McGraw - Hill Companies, srl 1 Ordinamenti ottimi.
Algoritmi e Strutture Dati
Capitolo 4 Ordinamento Algoritmi e Strutture Dati.
Camil Demetrescu, Irene Finocchi, Giuseppe F. ItalianoAlgoritmi e strutture dati Copyright © The McGraw - Hill Companies, srl 1 Usa la tecnica del.
Algoritmi e Strutture Dati
Algoritmi e Strutture Dati
Capitolo 4 Ordinamento Algoritmi e Strutture Dati Camil Demetrescu, Irene Finocchi, Giuseppe F. Italiano.
Camil Demetrescu, Irene Finocchi, Giuseppe F. ItalianoAlgoritmi e strutture dati Copyright © The McGraw - Hill Companies, srl 1 Strutture dati per.
Camil Demetrescu, Irene Finocchi, Giuseppe F. ItalianoAlgoritmi e strutture dati Copyright © The McGraw - Hill Companies, srl 1 Usa la tecnica del.
Algoritmi e Strutture Dati
Camil Demetrescu, Irene Finocchi, Giuseppe F. ItalianoAlgoritmi e strutture dati Capitolo 12 Minimo albero ricoprente: Algoritmi di Prim e di Borůvka Algoritmi.
U V U V (a) |cfc|=2 prima e dopo (b) |cfc|=2 prima e |cfc|=1 dopo
Camil Demetrescu, Irene Finocchi, Giuseppe F. ItalianoAlgoritmi e strutture dati Copyright © The McGraw - Hill Companies, srl Capitolo 6 Interrogazioni.
Capitolo 13 Cammini minimi: Algoritmo di Floyd e Warshall Algoritmi e Strutture Dati.
Camil Demetrescu, Irene Finocchi, Giuseppe F. ItalianoAlgoritmi e strutture dati Capitolo 12 Minimo albero ricoprente: Algoritmi di Prim e di Borůvka Algoritmi.
Camil Demetrescu, Irene Finocchi, Giuseppe F. ItalianoAlgoritmi e strutture dati Capitolo 4 Ordinamento: Heapsort Algoritmi e Strutture Dati.
Capitolo 11 Grafi e visite di grafi Algoritmi e Strutture Dati.
Camil Demetrescu, Irene Finocchi, Giuseppe F. ItalianoAlgoritmi e strutture dati Capitolo 12 Minimo albero ricoprente: Algoritmi di Prim e di Boruvka Algoritmi.
Camil Demetrescu, Irene Finocchi, Giuseppe F. ItalianoAlgoritmi e strutture dati Copyright © The McGraw - Hill Companies, srl Capitolo 8 Code con.
Algoritmi e Strutture Dati
Algoritmi e Strutture Dati
Camil Demetrescu, Irene Finocchi, Giuseppe F. ItalianoAlgoritmi e strutture dati Copyright © The McGraw - Hill Companies, srl Capitolo 6 Il problema.
Algoritmi e Strutture Dati
Visite di grafi Algoritmi e Strutture Dati. Camil Demetrescu, Irene Finocchi, Giuseppe F. ItalianoAlgoritmi e strutture dati Copyright © The McGraw.
Capitolo 4 Ordinamento Algoritmi e Strutture Dati.
Capitolo 9 Il problema della gestione di insiemi disgiunti (Union-find) Algoritmi e Strutture Dati.
Camil Demetrescu, Irene Finocchi, Giuseppe F. ItalianoAlgoritmi e strutture dati Capitolo 12 Minimo albero ricoprente: Algoritmi di Prim e di Borůvka Algoritmi.
Camil Demetrescu, Irene Finocchi, Giuseppe F. ItalianoAlgoritmi e strutture dati Copyright © The McGraw - Hill Companies, srl 1 Un albero è un grafo.
Capitolo 11 Grafi e visite di grafi Algoritmi e Strutture Dati.
Capitolo 11 Grafi e visite di grafi Algoritmi e Strutture Dati.
Algoritmi e Strutture Dati
Algoritmi e Strutture Dati
Algoritmi e Strutture Dati
Camil Demetrescu, Irene Finocchi, Giuseppe F. ItalianoAlgoritmi e strutture dati Copyright © The McGraw - Hill Companies, srl 1 K 4 è planare? Sì!
Algoritmi e Strutture Dati
Camil Demetrescu, Irene Finocchi, Giuseppe F. ItalianoAlgoritmi e strutture dati Capitolo 12 Minimo albero ricoprente: Algoritmi di Prim e di Borůvka Algoritmi.
Camil Demetrescu, Irene Finocchi, Giuseppe F. ItalianoAlgoritmi e strutture dati Copyright © The McGraw - Hill Companies, srl 1 Strutture dati per.
Capitolo 9 Il problema della gestione di insiemi disgiunti (Union-find) Algoritmi e Strutture Dati.
Capitolo 13 Cammini minimi: Algoritmo di Floyd e Warshall Algoritmi e Strutture Dati.
Capitolo 13 Cammini minimi: Ordinamento topologico Algoritmi e Strutture Dati.
Capitolo 12 Minimo albero ricoprente: Algoritmo di Kruskal (*) Algoritmi e Strutture Dati.
Capitolo 12 Minimo albero ricoprente Algoritmi e Strutture Dati.
Capitolo 9 Union-find Algoritmi e Strutture Dati.
Capitolo 12 Minimo albero ricoprente: Algoritmo di Kruskal Algoritmi e Strutture Dati.
Capitolo 13 Cammini minimi Algoritmi e Strutture Dati.
Capitolo 11 Visite di grafi Algoritmi e Strutture Dati.
Algoritmi e Strutture Dati
Capitolo 13 Cammini minimi: Bellman e Ford Algoritmi e Strutture Dati.
Capitolo 13 Cammini minimi: Algoritmo di ordinamento topologico, di Dijkstra, e di Floyd e Warshall Algoritmi e Strutture Dati.
Capitolo 13 Cammini minimi Algoritmi e Strutture Dati.
Capitolo 13 Cammini minimi: algoritmo di Dijkstra Algoritmi e Strutture Dati.
Algoritmi e Strutture Dati
Cammini minimi fra tutte le coppie:
Camil Demetrescu, Irene Finocchi, Giuseppe F. ItalianoAlgoritmi e strutture dati Capitolo 12 Minimo albero ricoprente: Algoritmo di Prim Algoritmi e Strutture.
Camil Demetrescu, Irene Finocchi, Giuseppe F. ItalianoAlgoritmi e strutture dati Capitolo 12 Minimo albero ricoprente: Algoritmo di Prim Algoritmi e Strutture.
Capitolo 9 Il problema della gestione di insiemi disgiunti (Union-find) Algoritmi e Strutture Dati.
Capitolo 12 Minimo albero ricoprente: Algoritmo di Kruskal Algoritmi e Strutture Dati.
Capitolo 11 Grafi e visite di grafi Algoritmi e Strutture Dati Camil Demetrescu, Irene Finocchi, Giuseppe F. Italiano.
Capitolo 13 Cammini minimi: algoritmo di Dijkstra Algoritmi e Strutture Dati.
Algoritmi e Strutture Dati
Algoritmi e Strutture Dati
Transcript della presentazione:

Algoritmi e Strutture Dati Capitolo 12 Minimo albero ricoprente: Algoritmo di Kruskal

Progettare una rete stradale Supponiamo di dover progettare una rete stradale in un quartiere di nuova costruzione, in cui il costo di costruzione di un collegamento punto a punto è direttamente proporzionale alla distanza fisica (euclidea) tra i due punti. Requisito minimo: connettività tra tutte le abitazioni. Copyright © 2004 - The McGraw - Hill Companies, srl

Una soluzione costosa Usa molti archi, alcuni dei quali sono ridondanti. Inoltre, gli archi usati sono molto costosi. Copyright © 2004 - The McGraw - Hill Companies, srl

Una soluzione ottima Usa il minimo numero di archi, di lunghezza complessiva minima! In termini teorici, è un minimo albero ricoprente del grafo completo euclideo avente per nodi le abitazioni, e per pesi degli archi la distanza euclidea dei relativi estremi. Copyright © 2004 - The McGraw - Hill Companies, srl

Definizioni Sia G=(V,E,w) un grafo non orientato, connesso e pesato (pesi reali). Un albero ricoprente di G è un sottografo T=(V,E′) di G tale che: T è un albero; T contiene tutti i vertici di G. Il costo dell’albero w(T) è la somma dei pesi degli archi appartenenti all’albero. Un minimo albero ricoprente di G è un albero ricoprente di G avente costo minimo. Copyright © 2004 - The McGraw - Hill Companies, srl

Esempi Il minimo albero ricoprente non è necessariamente unico Copyright © 2004 - The McGraw - Hill Companies, srl

Proprietà dei minimi alberi ricoprenti Copyright © 2004 - The McGraw - Hill Companies, srl

Tagli e cicli Dato un grafo non orientato G=(V,E), un taglio in G è una partizione dei vertici V in due insiemi (disgiunti): X e Y=V-X. Un arco e=(u,v) attraversa il taglio (X,Y) se uX e vY Ricorda: un ciclo è un cammino in cui il primo e l’ultimo vertice coincidono Copyright © 2004 - The McGraw - Hill Companies, srl

Un approccio “goloso” Costruiremo un minimo albero ricoprente un arco alla volta, effettuando scelte localmente “golose”. Ad esempio: includere nella soluzione archi di costo piccolo escludere dalla soluzione archi di costo elevato Formalizzeremo il processo come un processo di colorazione: archi blu: inclusi nella soluzione archi rossi: esclusi dalla soluzione Copyright © 2004 - The McGraw - Hill Companies, srl

Regola del taglio (regola blu) Scegli un taglio che non contiene archi blu. Tra tutti gli archi non colorati del taglio, scegline uno di costo minimo e coloralo blu. Ogni albero ricoprente deve infatti contenere almeno un arco del taglio E’ naturale includere quello di costo minimo Copyright © 2004 - The McGraw - Hill Companies, srl

Teorema dei tagli Teorema: Dato il grafo G=(V,E,w) non orientato e pesato, e dato un taglio C=(X,Y) in G, un arco e=(u,v) di peso minimo che attraversa il taglio C appartiene sempre ad un qualche MAR di G. Dim. (per assurdo): Supponiamo per assurdo che e non appartenga ad alcun MAR di G. Sia T=(V,E′) un qualsiasi MAR di G, e consideriamo il taglio C in T. Copyright © 2004 - The McGraw - Hill Companies, srl

Teorema dei tagli X Aggiungendo l’arco e=(u,v) a T ottengo un ciclo in T, e tale ciclo contiene almeno un arco di T che attraversa il taglio. u x Allora, l’albero T' ottenuto da T sostituendo uno qualsiasi di tali archi con l’arco (u,v), è un albero ricoprente di G non più pesante di T, che per ipotesi era un MAR  T' è un MAR di G e (u,v) gli appartiene  contraddizione! v Y y w(u,v) ≤ w(x,y) Copyright © 2004 - The McGraw - Hill Companies, srl

Regola del ciclo (regola rossa) Scegli un ciclo che non contiene archi rossi. Tra tutti gli archi non colorati del ciclo, scegline uno di costo massimo e coloralo rosso. Ogni albero ricoprente deve infatti escludere almeno un arco del ciclo E’ naturale escludere quello di costo massimo Copyright © 2004 - The McGraw - Hill Companies, srl

Teorema dei cicli Teorema: Sia G=(V,E,w) un grafo non orientato e pesato, sia e l’arco strettamente più pesante di un qualsiasi ciclo in G. Allora e non può appartenere ad alcun MAR di G. Dim. (per assurdo): Sia e l’arco più pesante in un ciclo C={e}P, e supponiamo eT, un MAR di G. Allora: X T′=T \ {e}  {e′} P w(e′) < w(e)  w(T′) < w(T) e e′T  T non è un MAR di G! V\X Copyright © 2004 - The McGraw - Hill Companies, srl

L’approccio “goloso” L’approccio goloso applica una delle due regole ad ogni passo, finché tutti gli archi sono colorati Si può dimostrare che esiste sempre un minimo albero ricoprente che contiene tutti gli archi blu e non contiene nessun arco rosso. Si può inoltre dimostrare che il metodo goloso colora tutti gli archi. A seconda della scelta della regola da applicare e del taglio/ciclo usato ad ogni passo, si ottengono dal metodo goloso diversi algoritmi con diversi tempi di esecuzione Copyright © 2004 - The McGraw - Hill Companies, srl

Algoritmo di Kruskal Copyright © 2004 - The McGraw - Hill Companies, srl

Strategia Mantiene una foresta di alberi blu, all’inizio tutti disgiunti Per ogni arco, in ordine non decrescente di costo, applica il seguente passo: se l’arco ha entrambi gli estremi nello stesso albero blu, applica la regola del ciclo e coloralo rosso, altrimenti applica la regola del taglio e coloralo blu I vertici nello stesso albero blu sono mantenuti tramite una struttura dati union/find Copyright © 2004 - The McGraw - Hill Companies, srl

Pseudocodice Copyright © 2004 - The McGraw - Hill Companies, srl

Esempio (1/2) Copyright © 2004 - The McGraw - Hill Companies, srl

Esempio (2/2) Copyright © 2004 - The McGraw - Hill Companies, srl

T(n,m)=O(m log n + n+ T(UF(n,m))= Analisi della complessità Su un grafo con m archi ed n nodi, si eseguono: Un ordinamento su m elementi (costo O(m log m)=O(m log n), nell’ipotesi che il grafo in input sia rappresentato tramite una lista di adiacenza)); n operazioni di Makeset (costo O(n)); 2m operazioni di Find; n-1 operazioni di Union. T(n,m)=O(m log n + n+ T(UF(n,m))= O(m log n + T(UF(n,m))) Copyright © 2004 - The McGraw - Hill Companies, srl

Analisi della complessità La complessità dipende da come viene risolto UF(n,m): Alberi QuickFind: T(UF(n,m))=O(n2+m)=O(n2)  T(n,m)=O(m log n + n2). Alberi QuickFind con euristica dell’unione bilanciata: T(UF(n,m))=O(n log n+m)  T(n,m)=O(m log n + n log n +m)=O(m log n). Alberi QuickUnion: T(UF(n,m))=O(n+mn)=O(nm)  T(n,m)=O(m log n + nm)=O(nm). Alberi QuickUnion con euristica dell’unione bilanciata: T(UF(n,m))=O(n+m log n)=O(m log n) T(n,m)=O(m log n + m log n)=O(m log n). Copyright © 2004 - The McGraw - Hill Companies, srl

Analisi della complessità Il tempo di esecuzione dell’algoritmo di Kruskal è O(m log n) nel caso peggiore (Utilizzando un algoritmo di ordinamento ottimo e gestendo la struttura dati union-find con alberi QuickFind con euristica di unione bilanciata, o alberi QuickUnion con euristica di unione bilanciata (by rank o by size)) Copyright © 2004 - The McGraw - Hill Companies, srl