Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Recensione HUAWEI Mate X7: un foldable ottimo, ma restano i soliti problemi
Recensione HUAWEI Mate X7: un foldable ottimo, ma restano i soliti problemi
Mate X7 rinnova la sfida nel segmento dei pieghevoli premium puntando su un design ancora più sottile e resistente, unito al ritorno dei processori proprietari della serie Kirin. L'assenza dei servizi Google e del 5G pesa ancora sull'esperienza utente, ma il comparto fotografico e la qualità costruttiva cercano di compensare queste mancanze strutturali con soluzioni ingegneristiche di altissimo livello
Nioh 3: souls-like punitivo e Action RPG
Nioh 3: souls-like punitivo e Action RPG
Nioh 3 aggiorna la formula Team NINJA con aree esplorabili più grandi, due stili di combattimento intercambiabili al volo (Samurai e Ninja) e un sistema di progressione pieno di attività, basi nemiche e sfide legate al Crogiolo. La recensione entra nel dettaglio su combattimento, build, progressione e requisiti PC
Test in super anteprima di Navimow i220 LiDAR: il robot tagliaerba per tutti
Test in super anteprima di Navimow i220 LiDAR: il robot tagliaerba per tutti
La facilità di installazione e la completa automazione di tutte le fasi di utilizzo, rendono questo prodotto l'ideale per molti clienti. Ecco com'è andata la nostra prova in anteprima
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 22-08-2008, 15:14   #1
unslee
Member
 
L'Avatar di unslee
 
Iscritto dal: Jun 2008
Messaggi: 40
[C++ / Ordinamento Quicksort] Problemi nella ricorsione

Ciao a tutti,
ormai da qualche giorno sono impantanato su un esercizio. Ci ho ragionato, l'ho rifatto da zero ... ma niente!

Quest'esercizio è all'intero del capitolo sui puntatori.

Il testo recita così:
Ordinamento quicksort; l'algoritmo di base per un array monodimensionale è il seguente:

a) Partizionamento: Prendete il primo elemento di un array non ordinato e determinate il suo indirizzo finale nell'array ordinato, vale a dire tutti i valori a sinistra dell'elemento sono minori e tutti i valori a destra sono maggiori. A questo punto si ha un elemento nell'indirizzo giusto e due sottoarray non ordinati.

b) Passo ricorsivo: Effettuate l'operazione precedente su ciascun sottoarray.

Scrivere la funzioni quicksort che ordina un array di interi monodimensionale. La funzione dovrebbe ricevere come argomenti l'array di interi, l'indice iniziale e l'indice finale. La funzione quickSort dovrebbe chiamare la funzione partition per effettuare il partizionamento.

Con altre indicazioni relative al partizionamento sono riuscito a metter su la funzione partition che
a) riceve un array un indice iniziale ed un indice finale
b) sistema al posto giusto il primo valore dell'array
c) restituisce alla funzione chiamante il valore sistemato

La fuzione chiamante (quickSort) tramite il valore che le restituisce la funzione partition riesce a determinare esattamente ila posizione del valore in questione.

A questo punto dovrei creare due sottoarray (uno con i valori a destra del primo valore sistemato, l'altro con i valori a sinistra) da ridare in pasto alla funzione partition ma la cosa qui si complica parecchio.

a) Se cerco di creare due sottoarray distinti mi trovo un muro davanti perché la dimensione deve essere una costante (nel nostro caso non lo è perchè il primo valore sistemato può trovarsi ovunque nell'array).

b) Se cerco di lavorare sull'array originario facendo variare le posizioni iniziali e le posizioni finali da dare in pasto a partition non riesco ad impostare la ricorsione.

Di seguito posto il codice. La perplessità è anche che, trattandosi di esercizio sul capitolo relativo ai puntatori, dovrei sfruttarne le potenzialita, ma non riesco a capire come!

Ringrazio anticipatamente tutti per l'aiuto.

Codice:
#include "stdafx.h"

#include <iostream>
using std::cout;
using std::endl;


int _tmain(int argc, _TCHAR* argv[])
{
	return 0;
}

void quickSort(int [], int, int);
int partition(int [], int, int);

int main()
{
	int a[10] = {3, 6, 5, 1, 2, 9, 8, 10, 11, 7};
	int indiceIniziale = 0;
	int indiceFinale = 9;

	quickSort(a, indiceIniziale, indiceFinale);

	for (int i = 0; i <= 9; i++)
		cout << a[i] << "-";

	cout << endl;

	return 0;
}

void quickSort(int a[], int indiceIniziale, int indiceFinale)
{
	
	int numberx = partition(a, indiceIniziale, indiceFinale);
	int position = 0;

	for (int i = indiceIniziale; i <= indiceFinale; i++)
		if (a[i] == numberx)
			position = i;
	
	for (int i = indiceIniziale; i < position; i++)
		{cout << a[i] << "-";
		counter1++;}

//Da qui non riesco più ad andare avanti!

	
}

int partition(int a[], int indiceIniziale, int indiceFinale)
{

int numberx = a[0];
int currentPosition = 0;
int previousPosition = 0;
int stopCicle = 1;
int stopWhile = 0;
int temp = 0;

for (int i = indiceFinale; i >= currentPosition && stopCicle == 1; i--)
	if (a[i] < a[currentPosition])
		{temp = a[i];
		a[i] = a[currentPosition];
		a[currentPosition] = temp;
		stopCicle = 0;}

for (int i = 0; i <= indiceFinale; i++)
cout << a[i] << "-";
cout << endl;

for (int i = 0; i < indiceFinale; i++)
	{if (a[i] == temp)
		previousPosition = i;
	if (a[i] == numberx)
		currentPosition = i;}

if (currentPosition != indiceIniziale && currentPosition != indiceFinale)
{

while (stopWhile == 0)
{
for (int i = 0; i < indiceFinale; i++)
	{if (a[i] == temp)
		previousPosition = i;
	if (a[i] == numberx)
		currentPosition = i;}

for (int i = previousPosition + 1; i <= currentPosition && stopCicle == 0; i++)
	if (a[i] > a [currentPosition])
		{temp = a[i];
		a[i] = a[currentPosition];
		a[currentPosition] = temp;
		stopCicle = 1;
		stopWhile = 0;}
	else
		stopWhile = 1;

for (int i = 0; i <= indiceFinale; i++)
cout << a[i] << "-";
cout << endl;

for (int i = 0; i < indiceFinale; i++)
	{if (a[i] == temp)
		previousPosition = i;
	if (a[i] == numberx)
		currentPosition = i;}

for (int i = previousPosition - 1; i >= currentPosition && stopCicle == 1; i--)
	if (a[i] < a [currentPosition])
		{temp = a[i];
		a[i] = a[currentPosition];
		a[currentPosition] = temp;
		stopCicle = 0;
		stopWhile = 0;}
	else
		stopWhile = 1;

	for (int i = 0; i <= indiceFinale; i++)
	cout << a[i] << "-";
	cout << endl;
}

}
cout << numberx << endl;
return numberx;

}
unslee è offline   Rispondi citando il messaggio o parte di esso
Old 22-08-2008, 15:43   #2
banryu79
Senior Member
 
L'Avatar di banryu79
 
Iscritto dal: Oct 2007
Città: Padova
Messaggi: 4131
Ciao unslee,
qui su wikipedia trovi una pagina dedicata al popolarissimo quicksort: verso l'inizio c'è la descrizione in pseudo-codice dell'implementazione ricorsiva.
Per divertiti puoi anche consultare il pseudo-codice della versione iterativa e provare a implementare anche quella.

Ci dedichi 30 min di attenta lettura e secondo me basta per dipanarti i dubbi
__________________

As long as you are basically literate in programming, you should be able to express any logical relationship you understand.
If you don’t understand a logical relationship, you can use the attempt to program it as a means to learn about it.
(Chris Crawford)
banryu79 è offline   Rispondi citando il messaggio o parte di esso
Old 22-08-2008, 15:53   #3
71104
Bannato
 
L'Avatar di 71104
 
Iscritto dal: Feb 2005
Città: Roma
Messaggi: 7029
Codice:
#include <cstdlib>

...

int Comparator(const void *Item1, const void *Item2)
{
	if (*(int*)Item1 < *(int*)Item2)
	{
		return -1;
	}
	else if (*(int*)Item1 > *(int*)Item2)
	{
		return 1;
	}
	else
	{
		return 0;
	}
}

void QuickSort(int *Array, size_t Count)
{
	qsort(Array, Count, sizeof(int), Comparator);
}
71104 è offline   Rispondi citando il messaggio o parte di esso
Old 22-08-2008, 15:55   #4
71104
Bannato
 
L'Avatar di 71104
 
Iscritto dal: Feb 2005
Città: Roma
Messaggi: 7029
anzi guarda, ti metto anche un'implementazione più efficiente
Codice:
#include <cstdlib>

...

int Comparator(const void *Item1, const void *Item2)
{
	return *(int*)Item1 - *(int*)Item2;
}

void QuickSort(int *Array, size_t Count)
{
	qsort(Array, Count, sizeof(int), Comparator);
}
71104 è offline   Rispondi citando il messaggio o parte di esso
Old 22-08-2008, 16:09   #5
unslee
Member
 
L'Avatar di unslee
 
Iscritto dal: Jun 2008
Messaggi: 40
Che dire ... uno spettacolo! rimango sempre senza parole!

Grazie a tutti per il preziosissimo aiuto.

Mi metto subito al lavoro per capire l'esercizio secondo le indicazioni di 71104. Non mancherò di approfondire su wikipedia come suggerito da banryu79.

Se non ci foste ... bisognerebbe inventarvi!.

A presto,

Unslee
unslee è offline   Rispondi citando il messaggio o parte di esso
Old 22-08-2008, 17:12   #6
banryu79
Senior Member
 
L'Avatar di banryu79
 
Iscritto dal: Oct 2007
Città: Padova
Messaggi: 4131
Solo un momento, l'ottimo codice di 71104 fa uso della funzione qsort presente nella libreria standard "cstdlib": se tu stai imparando dalle basi allora ti consiglio di:
- leggerti le risorse online sul quick sort
- scrivere una tua implementazione dell'algoritmo (anche per via dell'esercizio sui puntatori)
- quindi leggere e capire quello che ha scritto 71104 e leggere e capire qsort

Ciao e buono studio
__________________

As long as you are basically literate in programming, you should be able to express any logical relationship you understand.
If you don’t understand a logical relationship, you can use the attempt to program it as a means to learn about it.
(Chris Crawford)
banryu79 è offline   Rispondi citando il messaggio o parte di esso
Old 22-08-2008, 18:32   #7
unslee
Member
 
L'Avatar di unslee
 
Iscritto dal: Jun 2008
Messaggi: 40
Grazie per il suggerimento. In effetti ho trovato la risoluzione di 71104 un pò complessa ed allora ne ho preso solo qualche spunto. Dopo aver studiato la problematica su wikipedia en e it sono riuscito a risolvere l'esercizio.

Di seguito la risoluzione completa. E' chiaro che qualsiasi suggerimento sarà gradito perchè sono veramente alle prime armi!

Codice:
#include "stdafx.h"

#include <iostream>
using std::cout;
using std::endl;


int _tmain(int argc, _TCHAR* argv[])
{
	return 0;
}

void quickSort(int [], int, int);
int partition(int [], int, int);

int main()
{
	int a[10] = {37, 2, 6, 4, 89, 8, 10, 12, 68, 45};
	int indiceIniziale = 0;
	int indiceFinale = 9;

	for (int i = 0; i <= 9; i++)
		cout << a[i] << "-";

	cout << endl;

	quickSort(a, indiceIniziale, indiceFinale);

	for (int i = 0; i <= 9; i++)
		cout << a[i] << "-";

	cout << endl;

	return 0;
}

void quickSort(int a[], int indiceIniziale, int indiceFinale)
{
	int positionx;

	if (indiceIniziale < indiceFinale)
	{
		positionx = partition(a, indiceIniziale, indiceFinale);
		
		
		quickSort(a, indiceIniziale, positionx - 1);
		quickSort(a, positionx + 1, indiceFinale);
	}

	return;
}

		

	

int partition(int a[], int indiceIniziale, int indiceFinale)
{

int numberx = a[indiceIniziale];
int currentPosition = 0;
int previousPosition = 0;
int stopCicle = 1;
int stopWhile = 0;
int temp = 0;

for (int i = indiceFinale; i > indiceIniziale && stopCicle == 1; i--)
	if (a[i] < a[indiceIniziale])
		{temp = a[i];
		a[i] = a[indiceIniziale];
		a[indiceIniziale] = temp;
		stopCicle = 0;}

for (int i = indiceIniziale; i <= indiceFinale; i++)
	{if (a[i] == temp)
		previousPosition = i;
	if (a[i] == numberx)
		currentPosition = i;}

if (currentPosition != indiceIniziale)
{

while (stopWhile == 0)
{
for (int i = indiceIniziale; i <= indiceFinale; i++)
	{if (a[i] == temp)
		previousPosition = i;
	if (a[i] == numberx)
		currentPosition = i;}

for (int i = previousPosition + 1; i <= currentPosition && stopCicle == 0; i++)
	if (a[i] > a [currentPosition])
		{temp = a[i];
		a[i] = a[currentPosition];
		a[currentPosition] = temp;
		stopCicle = 1;
		stopWhile = 0;}
	else
		stopWhile = 1;

for (int i = indiceIniziale; i <= indiceFinale; i++)
	{if (a[i] == temp)
		previousPosition = i;
	if (a[i] == numberx)
		currentPosition = i;}

for (int i = previousPosition - 1; i >= currentPosition && stopCicle == 1; i--)
	if (a[i] < a [currentPosition])
		{temp = a[i];
		a[i] = a[currentPosition];
		a[currentPosition] = temp;
		stopCicle = 0;
		stopWhile = 0;}
	else
		stopWhile = 1;

}

}

for (int i = 0; i < indiceFinale; i++)
	if (a[i] == numberx)
		return i;
}
unslee è offline   Rispondi citando il messaggio o parte di esso
Old 22-08-2008, 18:33   #8
unslee
Member
 
L'Avatar di unslee
 
Iscritto dal: Jun 2008
Messaggi: 40
... dimenticavo! Visto che il programma gira mi piacerebbe sapere se, dato il tipo di soluzione che ho adottato, l'utilizzo dei puntatori è consigliato e come implementarlo.

Grazie ancora per la collaborazione!

Unslee
unslee è offline   Rispondi citando il messaggio o parte di esso
Old 22-08-2008, 21:59   #9
Noixe
Member
 
Iscritto dal: Aug 2008
Messaggi: 51
mmm tempo fa scrissi questa versione di quicksort molto più breve, non so se possa servirti:

Codice:
#include <iostream>

const int max = 10;

int vettore [max];

void swap (int& a, int& b) {
int temp = a;
    a = b;
    b = temp;
};

void quicksort(int left, int right, int array []) {
int i = 0, j = 0, pivot = 0;

        i = left;
        j = right;
        pivot = array[(left + right) / 2];
        do {
	        while (array[i] < pivot)
                  i++;
            while (pivot < array[j])
	              j--;
            if (i <= j) {
              swap(array[i++], array[j--]);
            };
        }
        while  (i <= j);
        if (left < j)
                quicksort(left, j, array);
        if (i < right)
                quicksort(i, right, array);
};


int main () {
    int j = 0;
	for (int i = max - 1; i >= 0; i--)
		vettore[j++] = rand();
		
	for (int i = 0; i < max - 1; i++)
	    std::cout << vettore[i] << std::endl;
     
    std::cout << "\nDopo l'ordinamento:\n" << std::endl;
    
	quicksort(0, max - 1, vettore);
	for (int i = 0; i < max; i++)
		std::cout << vettore[i] << std::endl;
	while(std::cin.get() != '\n');
    return 0;
}
Ciao
Noixe è offline   Rispondi citando il messaggio o parte di esso
Old 23-08-2008, 12:03   #10
71104
Bannato
 
L'Avatar di 71104
 
Iscritto dal: Feb 2005
Città: Roma
Messaggi: 7029
Quote:
Originariamente inviato da unslee Guarda i messaggi
In effetti ho trovato la risoluzione di 71104 un pò complessa
71104 è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


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
Test in super anteprima di Navimow i220 LiDAR: il robot tagliaerba per tutti Test in super anteprima di Navimow i220 LiDAR: i...
Dark Perk Ergo e Sym provati tra wireless, software via browser e peso ridotto Dark Perk Ergo e Sym provati tra wireless, softw...
DJI RS 5: stabilizzazione e tracking intelligente per ogni videomaker DJI RS 5: stabilizzazione e tracking intelligent...
Windows domina su Steam, ma molti utenti...
Per non incorrere in nuovi aumenti delle...
Cubi Z AI 8M visto da vicino, un mini-PC...
Datacenter nello Spazio, affascinante ma...
Social e minori, Butti apre al dibattito...
Tutte le offerte Amazon del weekend, sol...
Amazon spinge sull'usato garantito: 10% ...
TikTok rischia una maxi-multa in Europa:...
Bose su Amazon: QuietComfort SC over ear...
Scope elettriche super accessoriate in o...
Umidità e muffa addio: questo deu...
DREAME Aqua10 Ultra Roller a 999€ &egrav...
500.000 kit gratis consegnati: Noctua fa...
Il MIT sperimenta il calcolo termico: op...
Sembra ormai certo: la prossima Xbox sar...
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:09.


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