mirror of
https://github.com/Steffo99/appunti-magistrali.git
synced 2024-11-29 05:14:18 +00:00
46 lines
1.3 KiB
Markdown
46 lines
1.3 KiB
Markdown
[[algoritmo di approssimazione]] di [[vertex cover]].
|
|
|
|
## Funzionamento
|
|
|
|
> [!Summary]
|
|
> Finchè ci sono [[arco di un grafo|archi]] nel [[grafo]]:
|
|
> 1. seleziona un [[arco di un grafo|arco]] qualsiasi
|
|
> 2. aggiungi i due [[nodo di un grafo|nodi]] che lo collegano al [[vertex cover]]
|
|
> 3. rimuovi dal [[grafo]] tutti gli [[arco di un grafo|archi]] adiacenti ai [[nodo di un grafo|nodi]] aggiunti
|
|
|
|
## [[algoritmo corretto|Correttezza]]
|
|
|
|
> [!Success]
|
|
> Dato che l'algoritmo termina solo quando tutti gli [[arco di un grafo|archi]] sono stati aggiunti, il risultato è sicuramente un [[vertex cover]].
|
|
>
|
|
> Si ha sicuramente terminazione, perchè ogni iterazione aggiunge almeno un [[arco di un grafo|arco]] al [[vertex cover]].
|
|
|
|
## [[fattore di approssimazione|Fattore di approssimazione]]
|
|
|
|
Il [[vertex cover]] [[soluzione ottima|ottimale]] ==something something metà dei nodi==
|
|
|
|
Il [[fattore di approssimazione]] è:
|
|
$$
|
|
\Huge 2
|
|
$$
|
|
|
|
## [[Costo computazionale]]
|
|
|
|
| Costo | [[notazione O-grande]] |
|
|
|-|-|
|
|
| [[spazio]] | ... |
|
|
| [[tempo]] | $O(Edges)$ |
|
|
|
|
### [[9 - Algoritmi distribuiti/1 - Problemi/tempo|Tempo]]
|
|
|
|
Nel caso peggiore, il numero di iterazioni effettuate è pari alla metà del numero degli [[arco di un grafo|archi]], cioè:
|
|
$$
|
|
\frac
|
|
{Edges}
|
|
{2}
|
|
$$
|
|
|
|
In [[notazione asintotica]]:
|
|
$$
|
|
\Large O(Edges)
|
|
$$
|