Interpolation search: differenze tra le versioni
Contenuto cancellato Contenuto aggiunto
m Bot: fix citazione web (v. discussione) |
Migliorato la pagina |
||
(7 versioni intermedie di 7 utenti non mostrate) | |||
Riga 1:
{{Algoritmo
|
|immagine =Interpolation sort.gif
|didascalia =Ricerca del numero 24 grazie all'algoritmo
|
|tempo = <math>O(n)</math>
|tempo migliore = <math>O(1)</math>
|
|
|ottimale =
}}
L{{'}}'''interpolation search''' è un [[algoritmo di ricerca]] di un dato valore chiave in un [[array]] ordinato tramite gli stessi valori delle chiavi. È il metodo corrispondente alla ricerca di un particolare termine all'interno di un [[dizionario]] o di un nominativo all'interno di un [[elenco telefonico]].
L'interpolation search può essere considerato come una generalizzazione della [[ricerca dicotomica]]; quest'ultima, infatti, segue lo stesso procedimento, ma non si basa sui valori degli estremi, bensì taglia il ''search space'' sempre a metà.
In media, il costo dell'algoritmo è di <math>log(log(
== Esempio di implementazione ==
Il seguente codice [[C++]] è un esempio di semplice implementazione.
<
template <typename T>
int interpolation_search(T arr[], int size, T key)
Riga 44:
return -1;
}
</syntaxhighlight>
<!-- Notice that having probed the list at index ''mid'', for reasons of loop control administration, this code sets either ''high'' or ''low'' to be not ''mid'' but an adjacent index, which ___location is then probed during the next iteration. Since an adjacent entry's value will not be much different the interpolation calculation is not much improved by this one step adjustment, at the cost of an additional reference to distant memory such as disc.
Riga 53:
== Voci correlate ==
* [[Ricerca sequenziale]]
* [[Ricerca dicotomica]]
* [[Hash table]]
== Collegamenti esterni ==
* {{cita web|http://www.dcc.uchile.cl/~rbaeza/handbook/algs/3/322.srch.p.html|Interpolation search|lingua=en}}
* {{cita web|http://www.nist.gov/dads/HTML/interpolationSearch.html|National Institute of Standards and Technology|lingua=en}}
* {{cita web|http://www.cs.technion.ac.il/~itai/publications/Algorithms/p550-perl.pdf|Interpolation Search - A Log LogN Search|lingua=en}}
{{
[[Categoria:Algoritmi di ricerca]]
|