Merge Sort Program in Java: differenza tra Merge Sort e Quicksort

Pubblicato: 2021-05-25

Sommario

Introduzione al programma Merge Sort in JAVA

Come suggerisce il nome, il programma di ordinamento merge in JAVA è un algoritmo di ordinamento. È stato classicamente concettualizzato come l'algoritmo divide et impera in JAVA. Il programma merge sort in Java funziona scomponendo ricorsivamente un array di input in due o più dei suoi sottoproblemi costitutivi finché questi non sono abbastanza semplici da essere risolti direttamente.

I sottoproblemi costitutivi possono essere simili o in qualche modo correlati al problema genitore. Le singole soluzioni a ciascun sottoproblema vengono quindi combinate per ottenere la soluzione al problema originario del genitore.

Come funziona il programma Merge Sort in Java?

Come ripetuto in precedenza, il programma di ordinamento unione in JAVA è un algoritmo divide et impera. È un ordinamento stabile, il che significa che gli elementi dell'array mantengono le loro posizioni originali l'uno rispetto all'altro durante il processo di ordinamento.

  • Dividere: In questo passaggio, un array di input viene diviso nelle sue due metà costituenti. Questo passaggio viene ripetuto continuamente per tutti i mezzi array risultanti fino a quando non ci sono più mezzi array da dividere ulteriormente.
  • Conquista: in questo passaggio, gli array divisi vengono ordinati e uniti dal basso verso l'alto per raggiungere l'array ordinato finale.

Differenza tra Quicksort e Merge Sort Program in Java

Sebbene funzionalmente simili, è necessario porre un'enfasi pertinente sulla differenza fondamentale tra quicksort e mergesort in JAVA.

  • Meccanismo : Quicksort è un algoritmo di ordinamento interno e sul posto, mentre il mergesort è un algoritmo di ordinamento esterno e fuori posto. In Quicksort, gli elementi vengono ordinati in base a un elemento chiave noto come pivot. Il pivot è generalmente il valore medio in una matrice di input. Gli elementi con un valore inferiore al pivot vengono spinti sul lato sinistro del pivot, mentre gli elementi con un valore maggiore sul lato destro del pivot. Qui, il lato sinistro è indicato come la partizione sinistra e il lato destro è indicato come la partizione destra. Al contrario, mergesort divide ripetutamente un array in due sottoarray (n/2) finché non rimane un solo elemento. Quindi combina i sottoarray per formare l'array ordinato.
  • Applicazione: mentre quicksort è adatto per piccoli array, mergesort funziona con qualsiasi array, indipendentemente dalle sue dimensioni.
  • Velocità : nel caso di Quicksort, più piccolo è il set di dati, più veloce sarà l'algoritmo. Mergesort, d'altra parte, funziona a una velocità costante per tutti i set di dati.
  • Requisiti di spazio e utilizzo della memoria: come accennato in precedenza, il mergesort è un algoritmo di ordinamento esterno e fuori luogo. La sua complessità spaziale è O (n). Pertanto, richiede una memoria aggiuntiva di (O (n)) per ordinare l'array ausiliario.

Leggi anche: Tipi di letterali in Java con esempi

Analisi della complessità temporale del programma Merge Sort in JAVA

Il programma merge sort in JAVA ha una complessità temporale di O (n*log n). Secondo Binary Search, ogni volta che un numero è diviso a metà in ogni passaggio, può essere rappresentato dalla funzione logaritmica 'log n'. Il numero di passi (al massimo) può essere rappresentato da log n +1. Il centro di ogni sottoarray è O (1).

Pertanto, per unire i sottoarray, sarà richiesto un tempo di esecuzione di O (n). Quindi, il tempo totale per il programma di ordinamento unione in JAVA diventa n (log n +1). Ciò equivale a una complessità temporale di O (n*log n) in tutti e tre i casi (peggiore, medio e migliore) poiché l'ordinamento di unione richiede sempre tempo lineare per unire due metà.

Impara i corsi di software online dalle migliori università del mondo. Guadagna programmi Executive PG, programmi di certificazione avanzati o programmi di master per accelerare la tua carriera.

Riassumendo

Proprio come i dati ordinati per gli esseri umani sono logicamente validi e più facili da comprendere, gli array ordinati sono più gestibili con cui i computer possono lavorare. È qui che il programma di ordinamento unione in JAVA si rivela vantaggioso. È un algoritmo di ordinamento efficiente, generico e basato sul confronto.

Se sei interessato a saperne di più su Java, lo sviluppo di software full-stack, dai un'occhiata al programma Executive PG di upGrad & IIIT-B in Full-stack Software Development, progettato per i professionisti che lavorano e offre oltre 500 ore di formazione rigorosa, 9+ progetti e incarichi, stato di Alumni IIIT-B, progetti pratici pratici e assistenza sul lavoro con le migliori aziende.

Che cos'è l'ordinamento nella programmazione?

L'ordinamento è la tecnica per mettere gli oggetti in un ordine particolare. Questo di solito viene fatto per renderli più gestibili o per facilitarne l'accesso. In informatica, abbiamo algoritmi di ordinamento per le strutture dati. Questi algoritmi di ordinamento possono essere suddivisi in due categorie. Uno è gli algoritmi di ordinamento basati sul confronto e l'altro è gli algoritmi di ordinamento basati sull'inserimento. Negli algoritmi di ordinamento basati sul confronto, un elemento viene confrontato con un altro elemento per trovare la chiave di ordinamento corrispondente, che è l'unica chiave comune tra loro. Negli algoritmi di ordinamento basati sull'inserimento, il nuovo elemento viene aggiunto all'inizio di un array e l'elemento posizionato alla fine viene spostato all'inizio.

Quali sono i tipi di algoritmi di ordinamento nella programmazione?

Gli algoritmi di ordinamento sono per lo più classificati in 3 tipi: ordinamento sequenziale, ordinamento parallelo, ordinamento partizionamento. L'ordinamento sequenziale è più facile da capire. È quello che usiamo quando stiamo ordinando nella nostra testa. Tutto è ordinato dal più piccolo al più grande. Gli algoritmi di ordinamento sequenziale più comuni sono l'ordinamento per inserimento, l'ordinamento a bolle, l'ordinamento rapido e l'ordinamento per unione. Tutti questi algoritmi di ordinamento possono essere facilmente parallelizzati. Nel caso dell'ordinamento parallelo, ciascuna delle attività dipende dal risultato dell'attività precedente. Quindi, l'ordine dell'output non è garantito. Due algoritmi di ordinamento parallelo utilizzati sono l'ordinamento topologico e il mergesort dal basso verso l'alto. Gli algoritmi di ordinamento del partizionamento tentano di partizionare l'array di input in modo che ogni sottoarray possa essere ordinato individualmente. Gli algoritmi di ordinamento del partizionamento includono ricerca binaria, concatenamento, ordinamento heap e ordinamento radix.

Quali sono le differenze tra ordinamento unione e ordinamento rapido?

Merge sort è un algoritmo divide et impera. Divide un elenco in due partizioni in base a un elemento pivot, ordina ricorsivamente ciascuna delle partizioni e quindi unisce l'output. Il passaggio di unione può essere eseguito con un ordinamento di unione parallelo. L'ordinamento rapido è un algoritmo di ordinamento O(nlogn). È un algoritmo molto più semplice, ma ogni volta deve ruotare su un elemento array casuale.