Rappresentazione e terminologia
-
Operazioni importanti
Definizione di grafo
È un insieme di nodi e di archi. (prendili da insiemi corretti)
Metodi di rappresentazione
Liste di incidenza
In pratica numero tutti gli archi e storo il valore dell’arco incidente per ogni nodo. Diventa una tabella con una parte i nodi e l’altra gli archi. Avrò dei valori -1 e 1 che marcano partenza e arrivo. La cosa carina di questo metodo è che può essere generalizzata anche per Ipergrafi, in cui gli archi possono avere più di una partenza o arrivo. Solitamente è memorizzato come una lista, quindi esattamente nodo partenza e arrivo per ogni edge.
Liste di adiacenza
Classico usato per Competitive, si memorizzano direttamente pointer a nodi di interesse. Quindi abbiamo una forma del genere: Nodo -> lista dei nodi a cui è collegato.
Matrici di adiacenza
Se esiste un arco fra due nodi, metto un uno in questa posizione (si può utilizzare una cosa simile per mantenere il peso di un arco)
Termini importanti
Cammino, cammino semplice, ciclo, ciclo semplice, fortemente e debolmetne connesso. grafo completo, aciclico
Cammino e cammino semplice
Ciclo
Componente debolmente connessa
Grafo completo
Grafo aciclico
Algoritmi sui grafi
Algoritmi di visita
BFS
DFS
Ordinamento topologico
È una dfs 😀è utile poi per utilizzare
`
Componenti fortemente connesse
È una relazione di equivalentz la raggiungibilità (anche per grafi indiretti) e quindi per connessione debole
Si può utilizzare l’algoritmo di Tarjan (credo si chiami cosi) per le SCC. si fa in m + n
Minimum Spanning Tree
Definizione di MST
Un sottografo di un grafo che prenda tutti i vertici, tale per cui la somma del peso degli archi presi sia la minima possibile.
Taglio di un grafo
Regole per l’intuizione della sol greedy
-
da libro
Kruscal
Si utilizza la union find,
Prim
Solo sulla frontiera, si espande usando la regola del taglio
Cammini minimi
Proprietà (sottostruttura e esistenza per connettività )
- Se ho un cammino minimo, allora anche un suo sotto cammino a un sottonodo è un cammino minimo
- Se ho un grafo connesso, allora esistono cammini minimi fra due nodi connessi
Condizione di Bellman
Questa è una condizione sul valore della distanza fra i nodi dei grafi:
Se ho $d_{xy} \leq d_{xp} + w(p, y)$, ovvero la distanza fra due nodi, è sempre minore o uguale alla distanza fra un nodo intermedio e l’arco fra questo nodo a y. È uguale se è il cammino minimo.
Da questa osservazione di può definire una condizione di rilassamento di un arco. Gli algoritmi di rilassamento partono da una condizione grossolana, poi approssimano qualcosa sempre meglio, volta dopo volta.
Algoritmo di Bellman-ford
Il pensiero per ricordarsi questo algoritmo è questa osservazione:
Suppongo di conoscere il cammino minimo da un vertice di partenza e un vertice di arrivo, allora sarebbe facile percorrerlo e conoscerne i costi. Noto che se provo a rilassare ogni singolo arco, allora dovrei aver almeno trovato il costo per il primo nodo del cammino. Continuo a fare così, con rilassamenti successivi finché non arrivo a uno stadio stabile.
Cerco di rilassare ogni arco finché qualcosa cambia, se cambia vuol dire che non ho ancora finito tutti i rilassamenti possibili.
-
Algoritmo
Nota:
Questo algoritmo è buono perché trova il cammino minimo anche per archi negativi ðŸŒ
Algoritmo di Dijkstra
Questo algoritmo funziona solamente nel caso in cui non ho archid i peso negativo.
-
Lemma fondamentale per comprendere Dijkstra
-
Algoritmo in pseudocodice generico
-
Algoritmo in pseudocodice con strutture di dati
Algoritmo di Floyd-Warshall
Utilizziamo la programmazione dinamica per calcolare tutti i percorsi minimi. L’idea è calcolare ad ogni step, una matrice di percorsi che passano per un certo specifico vertice.
- Algoritmo in pseudocodice (si può ottimizzare lo spazio in questo)
Dopo Part of Speech Tagging e Transliteration systems si può tradurre questo algoritmo come programmazione dinamica su grafi su un semi-anello artico.