Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Recensione vivo X300 Pro: è ancora lui il re della fotografia mobile, peccato per la batteria
Recensione vivo X300 Pro: è ancora lui il re della fotografia mobile, peccato per la batteria
vivo X300 Pro rappresenta un'evoluzione misurata della serie fotografica del produttore cinese, con un sistema di fotocamere migliorato, chipset Dimensity 9500 di ultima generazione e l'arrivo dell'interfaccia OriginOS 6 anche sui modelli internazionali. La scelta di limitare la batteria a 5.440mAh nel mercato europeo, rispetto ai 6.510mAh disponibili altrove, fa storcere un po' il naso
Lenovo Legion Go 2: Ryzen Z2 Extreme e OLED 8,8'' per spingere gli handheld gaming PC al massimo
Lenovo Legion Go 2: Ryzen Z2 Extreme e OLED 8,8'' per spingere gli handheld gaming PC al massimo
Lenovo Legion Go 2 è la nuova handheld PC gaming con processore AMD Ryzen Z2 Extreme (8 core Zen 5/5c, GPU RDNA 3.5 16 CU) e schermo OLED 8,8" 1920x1200 144Hz. È dotata anche di controller rimovibili TrueStrike con joystick Hall effect e una batteria da 74Wh. Rispetto al dispositivo che l'ha preceduta, migliora ergonomia e prestazioni a basse risoluzioni, ma pesa 920g e costa 1.299€ nella configurazione con 32GB RAM/1TB SSD e Z2 Extreme
AWS re:Invent 2025: inizia l'era dell'AI-as-a-Service con al centro gli agenti
AWS re:Invent 2025: inizia l'era dell'AI-as-a-Service con al centro gli agenti
A re:Invent 2025, AWS mostra un’evoluzione profonda della propria strategia: l’IA diventa una piattaforma di servizi sempre più pronta all’uso, con agenti e modelli preconfigurati che accelerano lo sviluppo, mentre il cloud resta la base imprescindibile per governare dati, complessità e lock-in in uno scenario sempre più orientato all’hybrid cloud
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 23-03-2007, 20:59   #1
Zagor HW
Senior Member
 
Iscritto dal: Jan 2005
Città: Cesena
Messaggi: 323
[c] Problema algoritmo Random_Select

Dovrei tradurre in C il pseudocodice dell'algoritmo del random select. Il pseudocodice è questo (è preso dal famoso libro "Introduction to Algorithm"):

Codice:
RANDOMIZED-SELECT(A, p, r, i)
    if p = r
        then return A[p]
    q = RANDOMIZED-PARTITION(A, p, r)
    k = q - p + 1
    if i = k 
        then return A[q]
    elseif i < k
        then return RANDOMIZED-SELECT(A, p, q - 1, i)
    else return RANDOMIZED-SELECT(A, q + 1, r, i - k)

RANDOMIZED-PARTITION(A, p, r)
 	i = RANDOM(p, r)
	exchange(A[r],A[i])
	return PARTITION(A, p, r)

PARTITION(A, p, r)
 	x = A[r]
 	i = p - 1

 	for j = p to r - 1
 		do if A[j] <= x
 			then i = i + 1
 				 exchange(A[i],A[j])
 	exchange(A[i + 1],A[r])
 	return i + 1
Il codice che ho creato in C è il seguente:

Codice:
#include <stdio.h>
#include <stdlib.h>
#include <time.h>
#define DIMENSIONE 5

int rand_select(int vet[DIMENSIONE],int inizio,int fine,int elemento);
int rand_partition(int vet[DIMENSIONE],int inizio,int fine);
int partition(int vet[DIMENSIONE],int inizio,int fine);
int genera_num_casuali(int min,int max);

int main()
{
	/*supponendo che il vettore sia gia stato inserito*/
	int vet[DIMENSIONE]={56,12,58,45,67},inizio=0,fine=1,elemento=0,ris=0;
	ris=rand_select(vet,inizio,fine,elemento);
	printf("l'elemento selezionato e':%d\n",ris);
	//printf("%d",vet[ris]);
	return 0;
}

int rand_select(int vet[DIMENSIONE],int inizio,int fine,int elemento)
{
	int q=0,appoggio=0;
	/*HO PROVATO A TOGLIERE IL CONTROLLO DI LUNGHEZZA 0 FORSE SERVE ANCHE PER LA RICORSIONE, AL MASSIMO LO SI METTE NEL MAIN*/
	if(inizio==fine)
		return vet[inizio];
	/*in q viene messa la posizione del pivot, dopo aver applicato
	  la funzione partition*/
	q=rand_partition(vet,inizio,fine);
	appoggio=q-inizio+1;
	/*se il la posizione dell'elemento da ricercare sta alla sinistra
	  del pivot appena calcolato, ripetiamo la select sulla parte
	  sinistra del vettore, altrimenti su quella destra*/
	if(elemento==appoggio)
		return vet[q];
	if(elemento<appoggio)
		return rand_select(vet,inizio,(q-1),elemento);
		else return rand_select(vet,(q+1),fine,(elemento-appoggio));
}

int rand_partition(int vet[DIMENSIONE],int inizio,int fine)
{
	int appoggio=0,scambio=0;
	/*determinazione del numero casuale*/
	appoggio=genera_num_casuali(inizio,fine);

	/*scambio un elemento scelto a "caso" con l'ultimo dell'array*/
	scambio=vet[fine];
	vet[fine]=vet[appoggio];
	vet[appoggio]=scambio;
	/*ritorno il valore che verra generato dalla partition*/
	return partition(vet,inizio,fine);	
}

int partition(int vet[DIMENSIONE],int inizio,int fine)
{
	int appoggio=0,pivot=0,i=0,j=0;
	
	/*prendiamo l'ultimo elemento come pivot*/
	pivot=vet[fine];
	i=inizio-1;
	/*ciclo che sposta i valori minori o uguli del pivot alla sinistra del pivot stesso*/
	/*e mette quelli maggiori alla sua destra*/
	for(j=inizio;j<(fine-1);++j)
	{
		if(vet[j]<=pivot)
		{
			i++;
			appoggio=vet[j];
			vet[j]=vet[i];
			vet[i]=appoggio;
		}
	}
	/*mettiamo il pivot (che era l'ultimo elemento) nella sua posizione*/
	/*in ogni fase del ciclo era sempre rimasto in fondo, con questa
	  operazione lo mettiamo "al suo posto", cioè tutti i numeri più
	  piccoli gli rimangono sulla sinistra, mentre quelli più grandi
	  sulla destra*/
	appoggio=vet[fine];
	vet[fine]=vet[i+1];
	vet[i+1]=appoggio;
	/*ritorniamo la posizione del pivot*/
	return ++i;
}

int genera_num_casuali(int min,int max)
{
	int numero_casuale;
	int differenza;
	differenza = (max - min) + 1;
	if(differenza!=0)
		numero_casuale = rand() % differenza ;
	numero_casuale = numero_casuale + min ;
	return numero_casuale;
}
Il problema è che selezionando un numero tra l'uno e il tre mi restituisce un valore sbagliato, mentre se provo a selezionare il valore 0 o 4 crasha perché la variabile fine (che indica la dimensione del vettore) arriva a raggiungere il valore -1, e dopo qualche ciclo si va a scrivere in una posizione non corretta.
Potete aiutarmi a trovare l'errore visto che sono giorni che guardo e riguardo ma non lo riesco a trovare?
(Il file .c è in allegato)

Grazie
Allegati
File Type: zip Rand Select.zip (1.3 KB, 2 visite)
Zagor HW è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Recensione vivo X300 Pro: è ancora lui il re della fotografia mobile, peccato per la batteria Recensione vivo X300 Pro: è ancora lui il...
Lenovo Legion Go 2: Ryzen Z2 Extreme e OLED 8,8'' per spingere gli handheld gaming PC al massimo Lenovo Legion Go 2: Ryzen Z2 Extreme e OLED 8,8'...
AWS re:Invent 2025: inizia l'era dell'AI-as-a-Service con al centro gli agenti AWS re:Invent 2025: inizia l'era dell'AI-as-a-Se...
Cos'è la bolla dell'IA e perché se ne parla Cos'è la bolla dell'IA e perché se...
BOOX Palma 2 Pro in prova: l'e-reader diventa a colori, e davvero tascabile BOOX Palma 2 Pro in prova: l'e-reader diventa a ...
Landspace si prepara al secondo lancio d...
Tutti gli sconti Apple su Amazon: tornan...
Altro che entry-level: due smartwatch Am...
Roscosmos ha posticipato (ancora) il lan...
Isar Aerospace si prepara al secondo lan...
Tory Bruno è entrato in Blue Orig...
Fujifilm lancia la cartuccia per archivi...
Dreame H15 Mix: la soluzione 7-in-1 per ...
AirPods Pro 3 in forte sconto su Amazon:...
36 offerte Amazon, molte appena partite:...
2 caricatori multipli eccezionali: da 28...
OLED e 360 Hz a un prezzo senza preceden...
Roborock Q10 S5+ a un prezzo molto conve...
Upgrade PC a prezzo ridotto: le migliori...
Sono i 6 smartphone migliori su Amazon: ...
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: 17:58.


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