Quickselect


Il Quickselect è un algoritmo randomizzato ricorsivo che trova l’elemento che si troverebbe in k-esima posizione se l’array in cui si trova fosse ordinato.

Su un array di grandezza n l’algoritmo esegue O(n^2) confronti nel caso peggiore e O(n) nel caso atteso. Si basa sull’algoritmo Quicksort.

L’idea di base che sta alla base dell’algoritmo è molto semplice: se si deve estrarre l’elemento che si troverebbe in k-esima posizione se l’array fosse ordinato, basta ordinare di volta in volta la porzione dell’array in cui l’elemento si troverebbe, trascurando il resto dell’array.

Ecco un’implementazione...

Leggi il seguito »



Invia questo articolo via email Invia questo articolo via email   
Novità: Sei stanco di ascoltare le solite cose? Ascolta questo post!

LEGGI LE ALTRE NOTIZIE DE "IL BLOGGATORE"   

Nessun commento

Leave a reply