Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Recensione Samsung Galaxy S26 Ultra: finalmente qualcosa di nuovo
Recensione Samsung Galaxy S26 Ultra: finalmente qualcosa di nuovo
Per diversi giorni il Galaxy S26 Ultra di Samsung è stato il nostro compagno di vita. Oltre alle conferme del colosso coreano come la qualità del display e una suite AI senza rivali, arriva il Privacy Display, un unicum nel mondo smartphone. Ci sono ancora alcuni gap che non sono riusciti a colmare lato batteria e fotocamera, seppur con alcuni miglioramenti.
Diablo II Resurrected: il nuovo DLC Reign of the Warlock
Diablo II Resurrected: il nuovo DLC Reign of the Warlock
Abbiamo provato per voi il nuovo DLC lanciato a sorpresa da Blizzard per Diablo II: Resurrected e quella che segue è una disamina dei nuovi contenuti che abbiamo avuto modo di sperimentare nel corso delle nostre sessioni di gioco, con particolare riguardo per la nuova classe dello Stregone
Deep Tech Revolution: così Area Science Park apre i laboratori alle startup
Deep Tech Revolution: così Area Science Park apre i laboratori alle startup
Siamo tornati nel parco tecnologico di Trieste per il kick-off del programma che mette a disposizione di cinque startup le infrastrutture di ricerca, dal sincrotrone Elettra ai laboratori di genomica e HPC. Roberto Pillon racconta il modello e la visione
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 07-06-2006, 17:57   #1
riemann_01
Member
 
Iscritto dal: May 2006
Messaggi: 38
[C++] quicksort

Ciao a tutti!
Per quale motivo il seguente algoritmo di ordinamento, da me scritto, non funziona correttamente? Non riesco a trovare l'errore. Chi puo' darmi una mano? Grazie in anticipo!!

Codice:
// quicksort.cc

#include <iostream>
using namespace std;

template <class T>
inline void my_swap(T& x, T& y)
{
	T temp = x;
	x = y;
	y = temp;
}

template <class T>
void fill(T* seq, int size)
{
	for(; size > 0; --size, ++seq) 
		cin >> *seq;
}

template <class T>
void print(T *seq, int size)
{
	for(; size > 0; --size, ++seq)
		cout << *seq << endl;
}

// trova l'elemento di confronto
template <class T>
T find_pivot(T* lm, T* rm)
{
	T val = *(lm + (rm - lm) / 2);
	return val;
}

// effettua la partizione
template <class T>
T* partition(T* lm, T* rm, T pivot)
{
	while(lm < rm) {
		while(*lm < pivot)
			++lm;
		while(*rm > pivot)
			--rm;
		if(lm < rm) {
			my_swap(*lm,*rm);
			++lm;
			--rm;
		}
	}
	return lm;
}

// algoritmo di ordinamento
template <class T>
void quicksort(T* seq, T* lm, T* rm)
{
	T pvt = find_pivot(lm,rm), *p;
	if(lm < rm) {
		p = partition(lm,rm,pvt);
		quicksort(seq,lm,p-1);
		quicksort(seq,p+1,rm);
	}
}

// prova
int main()
{
	int a[10];
	
	cout << "Insert 10 integers (to confirm press ENTER)\n";
	fill(a,10);
	cout << "Sorted sequence\n";
	quicksort(a,&a[0],&a[10-1]);
	print(a,10);
}
Codice:
Insert 10 integers (to confirm press ENTER)
100
10
200
-100
-200
-101
100
-23
0
23
Sorted sequence
-200
10
-101
-100
-23
0
23
100
100
200

----------------------------------------------
Program exited successfully with errcode (0)
Press the Enter key to close this terminal ...
riemann_01 è offline   Rispondi citando il messaggio o parte di esso
Old 08-06-2006, 09:34   #2
trallallero
Senior Member
 
L'Avatar di trallallero
 
Iscritto dal: May 2006
Città: Wursteland
Messaggi: 1749
Codice:
// quicksort.cc

void quicksort(T* seq, T* lm, T* rm)
{
	T pvt = find_pivot(lm,rm), *p;
	if(lm < rm) {
		p = partition(lm,rm,pvt);
		quicksort(seq,lm,p-1);
		quicksort(seq,p+1,rm);
	}
}
cosi' ad occhio p-1 e p+1 potrebbero sforare.

in un array da lm a rm
p-1
potrebbe essere < lm
p+1 > rm ...

io aggiungerei un controllo tipo (solo per debuggure)

Codice:
      if ( (p-1) < lm )
         cout << "MINORE" << endl;
      if ( (p+1) > rm )
         cout << "MAGGIORE" << endl;
spero ti serva a qualcosa
trallallero è offline   Rispondi citando il messaggio o parte di esso
Old 09-06-2006, 00:12   #3
Qu@ker
Member
 
Iscritto dal: Apr 2004
Messaggi: 130
Il pivot li' in mezzo all'array da' qualche problema quando tenti di riordinare.
Spesso in questi casi lo si sposta alla fine dell'array, si ordina il resto e poi
si mette il pivot nella posizione 'giusta'.
Faccio un esempio sulla falsariga del tuo:
Codice:
#include <iostream>
#include <algorithm>
using namespace std;

template <class T>
void fill(T* seq, int size)
{
	for(; size > 0; --size, ++seq) 
		cin >> *seq;
}

template <class T>
void print(T *seq, int size)
{
	for(; size > 0; --size)
		cout << *seq++ << " ";
	cout << endl;
}

template <class T>
inline
T* find_pivot(T* lm, T* rm)
{
	return (lm + (rm - lm) / 2);
}

template <class T>
T* partition(T* inizio, T* fine, T *pivot)
{
        T *lm = inizio, *rm = fine-1;
        swap(*pivot, *fine);
        for (;;) {
	        while(*lm < *fine)
			++lm;
		while(*rm > *fine) 
			if (--rm == inizio)
				break;
		if (lm >= rm)
			break;
                swap(*lm, *rm);
                ++lm;
                --rm;
        }
        std::swap(*lm, *fine);

        return lm;
}

template <class T>
void quicksort(T* seq, T* lm, T* rm)
{
	if (rm <= lm)
		return;
	T *p = partition(lm,rm,find_pivot(lm,rm));
	quicksort(seq,lm,p-1);
	quicksort(seq,p+1,rm);
}

int main()
{
	int a[10];
	
	cout << "Insert 10 integers (to confirm press ENTER)\n";
	fill(a,10);
	cout << "Sorted sequence\n";
	quicksort(a,&a[0],&a[9]);
	print(a,10);
}
Codice:
bash-3.00$ ./qsort
Insert 10 integers (to confirm press ENTER)
100 10 200 -100 -200 -101 100 -23 0 23
Sorted sequence
-200 -101 -100 -23 0 10 23 100 100 200
bash-3.00$
Qu@ker è offline   Rispondi citando il messaggio o parte di esso
Old 11-06-2006, 19:00   #4
riemann_01
Member
 
Iscritto dal: May 2006
Messaggi: 38
Grazie ai vostri consigli sono riuscito a rilevare l'errore.
Riporto la versione corretta.

Codice:
// quicksort.h

#include <iostream>
using namespace std;

template <class T>
void fill(T *seq, int dim)
{
	for(; dim > 0; --dim, ++seq)
		cin >> *seq;
}

template <class T>
void print(T *seq, int dim)
{
	for(; dim > 0; --dim, ++seq)
		cout << *seq << endl;
}

template <class T>
inline void swap(T *x, T *y)
{
	T temp = *x;
	*x = *y;
	*y = temp;
}

template <class T>
void quicksort(T *seq, T *lm, T *rm)
{
	if(rm > lm) {
		T *i = lm - 1, *j = rm - 1, *pivot = rm;
		
		for(;;) {
			while(*(++i) < *pivot);
			while((*j > *pivot) && (--j >= lm));
			if(i < j)
				::swap(i,j);
			else
				break;
		}
		::swap(i,rm);
		quicksort(seq,lm,i-1);
		quicksort(seq,i+1,rm);
	}
}
Codice:
// quicksort.cc

#include "quicksort.h"

const int SIZE = 10;

int main()
{
	int d[SIZE];
	
	cout << "Insert " << SIZE << " integers (to confirm press ENTER)\n";
	fill(d,SIZE),
	cout << "Sorting...\n";
	quicksort(d,&d[0],&d[SIZE-1]);
	print(d,SIZE);
}
riemann_01 è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Recensione Samsung Galaxy S26 Ultra: finalmente qualcosa di nuovo Recensione Samsung Galaxy S26 Ultra: finalmente ...
Diablo II Resurrected: il nuovo DLC Reign of the Warlock Diablo II Resurrected: il nuovo DLC Reign of the...
Deep Tech Revolution: così Area Science Park apre i laboratori alle startup Deep Tech Revolution: così Area Science P...
HP OMEN MAX 16 con RTX 5080: potenza da desktop replacement a prezzo competitivo HP OMEN MAX 16 con RTX 5080: potenza da desktop ...
Recensione Google Pixel 10a, si migliora poco ma è sempre un'ottima scelta Recensione Google Pixel 10a, si migliora poco ma...
Spotify introduce 'Taste Profile': il co...
Sole e pioggia insieme: il nuovo pannell...
AWS e Cerebras uniscono le forze: nuova ...
Windows 11: accesso al drive C: bloccato...
BYD pronta a comprare un marchio storico...
Windows 11 si prepara ai monitor oltre i...
Apple avrebbe fissato un target di vendi...
Ultimi giorni per sfruttare le Offerte d...
I migliori smartphone in offerta ora su ...
Le migliori TV delle Offerte di Primaver...
Uno dei robot più avanzati del 2025 crol...
Robot aspirapolvere con stazione automat...
Il nuovo top di gamma compatto di OPPO n...
Nilox aggiorna la sua gamma di fat e-bik...
Meta valuta tagli fino al 20% della forz...
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: 07:05.


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