Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Panasonic 55Z95BEG cala gli assi: pannello Tandem e audio senza compromessi
Panasonic 55Z95BEG cala gli assi: pannello Tandem e audio senza compromessi
Con un prezzo di 2.999 euro, il Panasonic Z95BEG entra nella fascia ultra-premium dei TV OLED: pannello Primary RGB Tandem, sistema di raffreddamento ThermalFlow, audio Technics integrato e funzioni gaming avanzate lo pongono come un punto di riferimento
HONOR Magic V5: il pieghevole ultra sottile e completo! La recensione
HONOR Magic V5: il pieghevole ultra sottile e completo! La recensione
Abbiamo provato per diverse settimane il nuovo Magic V5 di HONOR, uno smartphone pieghevole che ci ha davvero stupito. Il device è il più sottile (solo 4.1mm) ma non gli manca praticamente nulla. Potenza garantita dallo Snapdragon 8 Elite, fotocamere di ottima qualità e batteria in silicio-carbonio che garantisce un'ottima autonomia. E il Prezzo? Vi diciamo tutto nella nostra recensione completa.
Recensione Google Pixel 10 Pro XL: uno zoom 100x assurdo sempre in tasca (e molto altro)
Recensione Google Pixel 10 Pro XL: uno zoom 100x assurdo sempre in tasca (e molto altro)
Google Pixel 10 Pro XL è il top di gamma della serie Pixel, presentando un ampio display Super Actua da 6.8 pollici insieme alle novità della serie, fra cui la ricarica wireless magnetica Pixelsnap e le nuove funzionalità AI avanzate. Il comparto fotografico include un sistema a tripla fotocamera con zoom Pro Res fino a 100x, mentre il processore Tensor G5 con 16GB di RAM garantisce prestazioni percepite molto elevate su Android.
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 14-09-2010, 14: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, 19: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, 21:09   #3
wingman87
Senior Member
 
Iscritto dal: Nov 2005
Messaggi: 2774
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, 21: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, 22:20   #5
wingman87
Senior Member
 
Iscritto dal: Nov 2005
Messaggi: 2774
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


Panasonic 55Z95BEG cala gli assi: pannello Tandem e audio senza compromessi Panasonic 55Z95BEG cala gli assi: pannello Tande...
HONOR Magic V5: il pieghevole ultra sottile e completo! La recensione HONOR Magic V5: il pieghevole ultra sottile e co...
Recensione Google Pixel 10 Pro XL: uno zoom 100x assurdo sempre in tasca (e molto altro) Recensione Google Pixel 10 Pro XL: uno zoom 100x...
Lenovo IdeaPad Slim 3: un notebook Snapdragon X economico Lenovo IdeaPad Slim 3: un notebook Snapdragon X ...
Recensione OnePlus Watch 3 43mm: lo smartwatch che mancava per i polsi più piccoli Recensione OnePlus Watch 3 43mm: lo smartwatch c...
Occhio alle batterie dei prossimi smartp...
'Così gli sviluppatori smetterann...
Il futuro dei chip sarà (molto) p...
I ladri colpiscono le guardie: dei cyber...
Casi-no incentivi statali, la campagna B...
Dopo la polemica, la resurrezione: The C...
Nuova truffa su WhatsApp: allarme dalla ...
Instagram testa il Picture-in-Picture pe...
Acer, le novità 'consumer' a IFA:...
Super sconti Amazon sulle telecamere Tap...
Dolby Vision 2 è ufficiale: un sa...
Realme non si ferma più: debutta ...
Perfect Dark poteva essere salvato: l’ac...
Acer presenta nuovi laptop, desktop e mo...
La mini workstation AI di Acer che rivol...
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: 21:42.


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