|
|||||||
|
|
|
![]() |
|
|
Strumenti |
|
|
#1 |
|
Senior Member
Iscritto dal: Jan 2005
Città: NAPOLI
Messaggi: 648
|
Esame di programmazione...sapete farlo?
Il mio professore mi ha assegnato questi 2 programmi da scrivre entro il 15 di ottobre....ma sto avendo grossissimi problemi, se qualcuno di voi sa farli o magari sa darmi qualke dritta gliene sarei immensamente grato....
TRACCIA : 1. algoritmo per “mischiare” un mazzo di carte francesi. L’algoritmo si basa sull’idea di scambiare effettivamente a coppie le carte del mazzo; una variabile in input permette di indicare quante volte si devono effettuare gli scambi (nei test usare i valori: 10,20,50,100,200). Usare la function rand(), il cui prototipo è in <stdlib.h>, per generare a ogni passo gli indici delle due carte da scambiare. Nei test, partire sempre dal mazzo “ordinato” e poi visualizzare il mazzo “mischiato”. Si ricorda che, se numero_casuale è dichiarata di tipo int, allora la chiamata numero_casuale=rand()%(n+1); genera un numero casuale intero (distribuzione uniforme) nell’insieme (0,1,2,..n). 2. variante dell’algoritmo di ricerca binaria che fa uso di numeri casuali. L’algoritmo, da implementare con tecnica ricorsiva, è una variante della versione standard, in cui l’indice dell’elemento da confrontare non è l’elemento di indice mediano della porzione sotto esame, ma è un indice generato a caso tra quelli che definiscono la porzione in esame; per esempio se la porzione è individuata dal primo indice =10 e dall’ultimo indice = 20, piuttosto che l’elemento di indice mediano (=15), si genera a caso un indice in (10,11,12,..,19,20) e si considera l’elemento di quell’indice nel confronto con la chiave e come elemento di partizione della porzione nelle due successive porzioni. Usare la function rand(), il cui prototipo è in <stdlib.h>, per generare a ogni passo l’indice dell’elemento da considerare a quel passo. Si ricorda che, se numero_casuale è dichiarata di tipo int, allora la chiamata numero_casuale=rand()%(n+1); genera un numero casuale intero (distribuzione uniforme) nell’insieme (0,1,2,..n). Oltre ai test normali, si deve effettuare il seguente test: il main definisce un array di size 1024 di int (da generare a caso in [-1000,1000]) e poi per 100 volte chiama la function di ricerca binaria su tale array, sempre con la stessa chiave che non deve appartenere all’array. Contare, per ogni chiamata, il numero di suddivisioni dell’array fatte dalla function (deve essere un dato di output della function) e alla fine visualizzare il valore medio del numero delle suddivisioni (sommare i 100 valori del numero delle suddivisioni e dividere tale somma per 100). Si ricorda che, nel caso di algoritmo standard di ricerca binaria, il numero di suddivisioni nel caso peggiore (chiave che non appartiene) è log2(1024)=10.
__________________
O'Napule dint'o'core.......... -MacBook 2,26 GHz Intel Core 2 Duo - 4 GB DDR3 -IPhone 3GS 16 GB -Ipad wifi+3g 64gb |
|
|
|
|
|
#2 | |
|
Senior Member
Iscritto dal: Jan 2005
Città: NAPOLI
Messaggi: 648
|
Quote:
__________________
O'Napule dint'o'core.......... -MacBook 2,26 GHz Intel Core 2 Duo - 4 GB DDR3 -IPhone 3GS 16 GB -Ipad wifi+3g 64gb |
|
|
|
|
|
|
#3 | |
|
Senior Member
Iscritto dal: Jun 2006
Città: Inverno: Novgorod. Estate: Haifa
Messaggi: 908
|
Quote:
quoto? al massimo autoquoto
__________________
Hosti non solum dandam esse viam ad fugiendum, sed etiam muniendam / Ceterum censeo Carthaginem esse delendam / Et facere et pati fortia romanum est / Nemo Romanorum pacis mentionem habere dignatus est / Roma locuta, causa finita Milla |
|
|
|
|
|
|
#5 |
|
Senior Member
Iscritto dal: Apr 2000
Città: Vicino a Montecatini(Pistoia) Moto:Kawasaki Ninja ZX-9R Scudetti: 29
Messaggi: 53971
|
Nessuno risponderà mai ad un quesito posto in questi termini, non possiamo fare l'intero esercizio per te, possiamo però darti una mano a partire dal codice che hai già fatto o un punto particolare del problema...
|
|
|
|
|
|
#6 | ||||||||
|
Moderatore
Iscritto dal: Nov 2003
Messaggi: 16213
|
Quote:
Quote:
Se ce li spieghi, forse possiamo aiutarti. Quote:
Quote:
Quote:
L'idea sembra abbastanza semplice: anzitutto, identifichi ogni carta con un numero tra 0 e 51, ad esempio parti da 0 = "due di picche", poi 1 = "tre di picche", e così via, fino a 51 = "asso di cuori". Poi, inizializzi un vettore carte, di 52 elementi, ponendo carte[n]=n per ogni n da 0 a 51. Poi, fai un certo numero di passi, in ciascuno dei quali chiami due volte rand per generare due interi pseudorandom n1 e n2 tra 0 e 51 inclusi, e scambiando di posto le carte corrispondenti, ossia scambiando i valori presenti in carte[n1] e carte[n2]. Quote:
Questo lo sa chiunque abbia letto il K&R e conosca un minimo di teoria dei generatori pseudorandom, ad esempio avendola letta sul secondo volume di "The Art of Computer Programming". Quote:
Stavolta, a ogni passo hai un indice jmin e un indice jmax, e devi generare un intero pseudorandom tra jmin e jmax inclusi. Se conosci l'algoritmo di ricerca binaria --- e dovresti conoscerlo, a questo punto del tuo corso di studi --- il resto viene da sé. Quote:
E' una fortuna che lo scopo dell'esercizio non sia trovare un elemento di un array, ma contare il numero medio di passi ricorsivi: cosa per la quale, in realtà, si fa presto a vedere che non è necessario che l'array sia ordinato. A proposito: il conteggio si può fare con una variabile globale, che viene passata alla funzione di ricerca binaria (ovviamente tramite puntatori) e incrementata a ogni chiamata ricorsiva.
__________________
Ubuntu è un'antica parola africana che significa "non so configurare Debian" Scienza e tecnica: Matematica - Fisica - Chimica - Informatica - Software scientifico - Consulti medici REGOLAMENTO DarthMaul = Asus FX505 Ryzen 7 3700U 8GB GeForce GTX 1650 Win10 + Ubuntu Ultima modifica di Ziosilvio : 10-10-2006 alle 11:01. |
||||||||
|
|
|
|
| Strumenti | |
|
|
Tutti gli orari sono GMT +1. Ora sono le: 08:15.











quoto? al massimo autoquoto








