Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Sony WF-1000X M6: le cuffie in-ear di riferimento migliorano ancora
Sony WF-1000X M6: le cuffie in-ear di riferimento migliorano ancora
WF-1000X M6 è la sesta generazione di auricolare in-ear sviluppata da Sony, un prodotto che punta a coniugare facilità di utilizzo con una elevata qualità di riproduzione dei contenuti audio e una cura nella riduzione del rumore ambientale che sia da riferimento
Snowflake porta l'IA dove sono i dati, anche grazie a un accordo con OpenAI
Snowflake porta l'IA dove sono i dati, anche grazie a un accordo con OpenAI
Snowflake ha presentato diverse novità per la sua piattaforma legate all'intelligenza artificiale. Quella forse più eclatante è una collaborazione con OpenAI, ma non mancano diverse nuove funzionalità che rendono la piattaforma più flessibile e in grado di rispondere meglio alle esigenze in continuo cambiamento delle aziende
Sistema Mesh Roamii BE Pro: il Wi-Fi 7 secondo MSI
Sistema Mesh Roamii BE Pro: il Wi-Fi 7 secondo MSI
Con velocità teoriche fino a 11 Gbps, gestione tramite app intelligente e protezione avanzata dei dispositivi, Roamii BE Pro porta il Wi‑Fi 7 tri‑band nelle abitazioni più esigenti. Un sistema Wi-Fi Mesh proposto da MSI allo scopo di garantire agli utenti una rete fluida e continua capace di sostenere streaming 8K, gaming competitivo e le applicazioni moderne più esigenti in termini di banda
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 14-09-2010, 15:13   #1
Negative_creep
Senior Member
 
L'Avatar di Negative_creep
 
Iscritto dal: Jul 2005
Città: Milano
Messaggi: 1078
Chiarimenti sul quicksort

Ciao a tutti, vorrei dei chiarimenti sul famoso algoritmo di quicksort. Da quanto ho capito dato un array A[n] di dimensione n, scelgo uno dei valori che sarà il mio PIVOT e utilizzo 2 indici "i" e "j" e attuo dei confronti/scambi di valori fino a trovare la posizione giusta per il mio pivot chiamando il metodo partition.

Ho provato l'algoritmo sulla frase A-S-O-R-T-I-N-G-E-X-A-M-P-L-E
e mentre sulle diverse lettere non ho avuto problemi, l'unica che non riesco a posizionare dall'inizio è la lettera "N" e qui mi sorge il dubbio sul fatto che non ho ben compreso l'algoritmo.

Vi scrivo il mio ragionamento. Scelgo N come pivot, inzio puntando i="A" e j="E", scorro la i e trovo "S" che è maggiore di N, mi fermo, guardo j, al momento punta ad E quindi attuo lo scambio fra S ed E ottenendo:

A-E-O-R-T-I-N-G-E-X-A-M-P-L-S

Ora i scorre di una posizione e trova subito la O, anche j decrementa e trova la L. Le scambio e mi trovo in questa situazione

A-E-L-R-T-I-N-G-E-X-A-M-P-O-S

Adesso scambio R con M ottendendo

A-E-L-M-T-I-N-G-E-X-A-R-P-O-S

In questo caso ora i punta a "T" e j punta a "A", scambio le due lettere con il seguente risultato A-E-L-M-A-I-N-G-E-X-T-R-P-O-S.

Ok, ora viene il problema, la i cerca una lettera > di "N" e la prima che trova è la "X", la j che puntava alla "T" decrementa di una posizione e si ritrova a puntare la "X" insieme il puntatore i.
i,j puntano a X quindi applico lo scambio mettendo la X in posizione di N e viceversa

A-E-L-M-A-I-X-G-E-N-T-R-P-O-S

La "N" in quella posizione non è corretta, e soprattutto prima del pivot N c'è la X che non fa parte di quella partition.
Il codice che ho tentato di utilizzare è il seguente




Sapete dirmi dove sbaglio?

Grazie in anticipo..
__________________
CPU: AMD Phenom II X4 965 C3 Motherboard: Asrock 980DE3/U3S3 R2.0 Ram: G-Skill F3 CL7 4GB DDR3 1333Mhz Alimentatore: Corsair VX550w Hard-Disk: Samsung SSD EVO 860 500GB - WD Caviar Black 1 TB
Negative_creep è offline   Rispondi citando il messaggio o parte di esso
Old 14-09-2010, 20:04   #2
Negative_creep
Senior Member
 
L'Avatar di Negative_creep
 
Iscritto dal: Jul 2005
Città: Milano
Messaggi: 1078
Nessuno?
__________________
CPU: AMD Phenom II X4 965 C3 Motherboard: Asrock 980DE3/U3S3 R2.0 Ram: G-Skill F3 CL7 4GB DDR3 1333Mhz Alimentatore: Corsair VX550w Hard-Disk: Samsung SSD EVO 860 500GB - WD Caviar Black 1 TB
Negative_creep è offline   Rispondi citando il messaggio o parte di esso
Old 14-09-2010, 22:09   #3
wingman87
Senior Member
 
Iscritto dal: Nov 2005
Messaggi: 2787
Quote:
Originariamente inviato da Negative_creep Guarda i messaggi
Ciao a tutti, vorrei dei chiarimenti sul famoso algoritmo di quicksort. Da quanto ho capito dato un array A[n] di dimensione n, scelgo uno dei valori che sarà il mio PIVOT e utilizzo 2 indici "i" e "j" e attuo dei confronti/scambi di valori fino a trovare la posizione giusta per il mio pivot chiamando il metodo partition.

Ho provato l'algoritmo sulla frase A-S-O-R-T-I-N-G-E-X-A-M-P-L-E
e mentre sulle diverse lettere non ho avuto problemi, l'unica che non riesco a posizionare dall'inizio è la lettera "N" e qui mi sorge il dubbio sul fatto che non ho ben compreso l'algoritmo.

Vi scrivo il mio ragionamento. Scelgo N come pivot
Hai già sbagliato qui scegliendo N, almeno se segui l'algoritmo che hai postato, perché quell'algoritmo sceglie sempre l'ultimo elemento, cioè nel tuo caso E
Quote:
Originariamente inviato da Negative_creep Guarda i messaggi
, inzio puntando i="A" e j="E", scorro la i e trovo "S" che è maggiore di N, mi fermo, guardo j, al momento punta ad E
Ma E non viene considerato perché il confronto che effettui è:
less(v,a[--j])
il predecremento prima di effettuare il confronto fa sì che l'elemento puntato da j sia L che è > E, quindi si decrementa ancora fino ad arrivare ad A, a quel punto si ferma ed effettui lo scambio. Poi vai avanti seguendo l'algoritmo.

Questo applicando l'algoritmo che hai postato, se invece vuoi scegliere tu il pivot puoi applicare lo stesso algoritmo mettendo però prima il pivot che hai scelto in fondo (nella posizione r).
Come vedi il pivot in questo modo non si muove mai, solo alla fine, all'uscita del for, viene scambiato con l'elemento in posizione i che è appunto la posizione giusta del pivot.
wingman87 è offline   Rispondi citando il messaggio o parte di esso
Old 14-09-2010, 22:51   #4
Negative_creep
Senior Member
 
L'Avatar di Negative_creep
 
Iscritto dal: Jul 2005
Città: Milano
Messaggi: 1078
Azz...Grazie mille
Praticamente l'algoritmo descritto dal libro fa la stessa cosa che dici tu giusto?
Sceglie sempre come pivot l'elemento in posizione R, che equivale a dire, scegli un pivot e mettilo in fondo, come hai suggerito tu, o sbaglio?


Comunque grazie veramente wingman87 per l'aiuto!!!
__________________
CPU: AMD Phenom II X4 965 C3 Motherboard: Asrock 980DE3/U3S3 R2.0 Ram: G-Skill F3 CL7 4GB DDR3 1333Mhz Alimentatore: Corsair VX550w Hard-Disk: Samsung SSD EVO 860 500GB - WD Caviar Black 1 TB
Negative_creep è offline   Rispondi citando il messaggio o parte di esso
Old 14-09-2010, 23:20   #5
wingman87
Senior Member
 
Iscritto dal: Nov 2005
Messaggi: 2787
Quote:
Originariamente inviato da Negative_creep Guarda i messaggi
Azz...Grazie mille
Praticamente l'algoritmo descritto dal libro fa la stessa cosa che dici tu giusto?
Sceglie sempre come pivot l'elemento in posizione R, che equivale a dire, scegli un pivot e mettilo in fondo, come hai suggerito tu, o sbaglio?
Esatto
Quote:
Originariamente inviato da Negative_creep Guarda i messaggi
Comunque grazie veramente wingman87 per l'aiuto!!!
Di nulla, sono contento di essere stato d'aiuto
wingman87 è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Sony WF-1000X M6: le cuffie in-ear di riferimento migliorano ancora Sony WF-1000X M6: le cuffie in-ear di riferiment...
Snowflake porta l'IA dove sono i dati, anche grazie a un accordo con OpenAI Snowflake porta l'IA dove sono i dati, anche gra...
Sistema Mesh Roamii BE Pro: il Wi-Fi 7 secondo MSI Sistema Mesh Roamii BE Pro: il Wi-Fi 7 secondo M...
Recensione HUAWEI Mate X7: un foldable ottimo, ma restano i soliti problemi Recensione HUAWEI Mate X7: un foldable ottimo, m...
Nioh 3: souls-like punitivo e Action RPG Nioh 3: souls-like punitivo e Action RPG
Apple conferma che l'arrivo della 'nuova...
Le vendite di Square Enix sono in netto ...
iPhone 17e si mostra in un video 'first ...
Il nuovo Xiaomi Watch 5 è pronto ...
Steam Deck è out of stock in dive...
Le migliori offerte Amazon del weekend, ...
PC più potente, meno spesa: su Amazon ta...
Amazon Haul: come fare acquisti 'pazzi' ...
Threads permetterà agli utenti di...
Monitor gaming in offerta su Amazon: 180...
Samsung vuole riconquistare la leadershi...
L'app di YouTube per Apple Vision Pro &e...
Fastweb + Vodafone: clienti e ricavi in ...
Artemis II: nuovo test prima del Wet Dre...
GTA 6 gratis se nasce un figlio il giorn...
Chromium
GPU-Z
OCCT
LibreOffice Portable
Opera One Portable
Opera One 106
CCleaner Portable
CCleaner Standard
Cpu-Z
Driver NVIDIA GeForce 546.65 WHQL
SmartFTP
Trillian
Google Chrome Portable
Google Chrome 120
VirtualBox
Tutti gli articoli Tutte le news Tutti i download

Strumenti

Regole
Non Puoi aprire nuove discussioni
Non Puoi rispondere ai messaggi
Non Puoi allegare file
Non Puoi modificare i tuoi messaggi

Il codice vB è On
Le Faccine sono On
Il codice [IMG] è On
Il codice HTML è Off
Vai al Forum


Tutti gli orari sono GMT +1. Ora sono le: 16:50.


Powered by vBulletin® Version 3.6.4
Copyright ©2000 - 2026, Jelsoft Enterprises Ltd.
Served by www3v