View Full Version : [C] Mastermind
Salve a tutti, sono nuovo del forum.
Devo fare un programma in C che realizzi il gioco Mastermind, non so se lo conoscete, altrimenti vi posto le regole, ma si trovano comunque su internet.
Devo utilizzare una metodologia top-down e utilizzare varie funzioni e strutture dati, mi potreste dare una mano ad implementarlo?
Quale funzioni mi consigliate e come usarle ?
Grazie a tutti in anticipo.
Sapete aiutarmi ?
Il gioco è questo: http://it.wikipedia.org/wiki/Mastermind
Nessuno che sappia aiutarmi?
E' abbastanza urgente.
Di cosa hai bisogno di preciso?
Io ne feci una versione moolto basilare a numeri...
Come utilizzare le funzioni, e come verificare se la sequenza di numeri inserita è uguale a quella generata dal computer, non so come fare, prima devo ordinare l'array? Come?
Come utilizzare le funzioni, e come verificare se la sequenza di numeri inserita è uguale a quella generata dal computer, non so come fare, prima devo ordinare l'array? Come?
la sequenza dei numeri (o dei colori come nel mastermind originale) deve rimanere nello stesso ordine con cui è stata generata ... quindi non devi ordinarla. Ma le regole del gioco le conosci ?
un bel po' di anni fa ho scritto un master-mind in gwbasic perchè avevo solo quello ... ma per curiostà perchè vuoi usare il C ?
la sequenza dei numeri (o dei colori come nel mastermind originale) deve rimanere nello stesso ordine con cui è stata generata ... quindi non devi ordinarla. Ma le regole del gioco le conosci ?
un bel po' di anni fa ho scritto un master-mind in gwbasic perchè avevo solo quello ... ma per curiostà perchè vuoi usare il C ?
DEVO usare il C. :D
Come utilizzare le funzioni, e come verificare se la sequenza di numeri inserita è uguale a quella generata dal computer, non so come fare, prima devo ordinare l'array? Come?
Intendi richiamare le funzioni?
O crearle con i relativi prototipi?
Passare argomenti alle funzioni?
Intendi richiamare le funzioni?
O crearle con i relativi prototipi?
Passare argomenti alle funzioni?
Si, anche questo.
Non dovrebbe essere troppo complicato.
Prima di tutto dovrai trovare il modo di generare i colori.
Dopodiché dovrai fare in modo che l'utente possa mettere in input la sua ipotesi.
A quel punto dovrai fare dei controlli e segnalare all'utente quali sono le posizioni azzeccate e quali sono i colori azzeccati (ma che non sono nella posizione giusta).
Leggi nuovamente l'input e vai così in maniera ciclica sugli ultimi 3 punti, finché non azzecca o finché l'utente si stufa :D.
Non dovrebbe essere troppo complicato.
Prima di tutto dovrai trovare il modo di generare i colori.
Dopodiché dovrai fare in modo che l'utente possa mettere in input la sua ipotesi.
A quel punto dovrai fare dei controlli e segnalare all'utente quali sono le posizioni azzeccate e quali sono i colori azzeccati (ma che non sono nella posizione giusta).
Leggi nuovamente l'input e vai così in maniera ciclica sugli ultimi 3 punti, finché non azzecca o finché l'utente si stufa :D.
Si, comunque devo usare i numeri, non i colori, e ho 15 tentativi massimo.
Non riesco a verificare se è uguale i numeri inseriti a quelli generati.
Si, comunque devo usare i numeri, non i colori, e ho 15 tentativi massimo.
Non riesco a verificare se è uguale i numeri inseriti a quelli generati.
Beh direi che potresti cominciare a postare qualche pezzo di codice, se vuoi che ti aiutiamo.
I numeri generati saranno messi da qualche parte in memoria, così come i numeri inseriti dall'utente.
Se conosci il linguaggio C ed in particolare gli array dovrebbe essere abbastanza banale fare il controllo, però dobbiamo vedere il codice per capire come hai impostato il problema.
Ok.
Questa è una parte del codice:
int Casuale() {
srand(time(NULL)); // inizializza il generatore di numeri casuali compreso fra 0 e num - 1
for(j=0;j<4;j++) {
do{
casuale[j]=(rand()%9+1); // genera una sequenza di 4 numeri composta da cifre da 1 a 9
}while(casuale[0]==casuale[1]||casuale[1]==casuale[2]||casuale[2]==casuale[3]);
}
printf("%i",casuale[j]);
}
int Acquisisci() {
for(i=0;i<4;i++) {
do{
printf("\nInserisci numero in posizione %i: ",i+1);
fflush(stdin);
scanf("%i",&num[i]);
}while(num[i]<1||num[i]>9);
}
}
int Verifica() {
int uguali=0;
for(i=0;i<4;i++) {
if(num[i]==casuale[j]) {
uguali=1;
}
}
if(uguali==1) {
printf("Bravo, hai indovinato !!!");
}
}
Non riesco a fare funzionare il verifica, e poi non mi acquisisce nemmeno tanto bene i numeri. :confused:
Ok.
Questa è una parte del codice:
int Casuale() {
srand(time(NULL)); // inizializza il generatore di numeri casuali compreso fra 0 e num - 1
for(j=0;j<4;j++) {
do{
casuale[j]=(rand()%9+1); // genera una sequenza di 4 numeri composta da cifre da 1 a 9
}while(casuale[0]==casuale[1]||casuale[1]==casuale[2]||casuale[2]==casuale[3]);
}
printf("%i",casuale[j]);
}
int Verifica() {
int uguali=0;
for(i=0;i<4;i++) {
if(num[i]==casuale[j]) {
uguali=1;
}
}
if(uguali==1) {
printf("Bravo, hai indovinato !!!");
}
}
Non riesco a fare funzionare il verifica, e poi non mi acquisisce nemmeno tanto bene i numeri. :confused:
Dunque, la funzione Casuale() potrebbe essere fatta meglio, perché IMHO fai troppi controlli, tuttavia per il momento se ti funziona lasciamola com'è...
Nella funzione Verifica() invece c'è qualcosa che non va, innanzitutto cosa vuoi verificare con quella funzione?
La presenza dei numeri o l'esatta posizione?
Poi quel j è una svista o vuoi farci qualcosa?
Al di là di questo, se consideriamo una situazione del genere:
computer: 1 2 3 4
utente: 1 6 7 8
Il tuo algoritmo mi direbbe che ho indovinato, quando invece non è vero.
Questo perché al primo passo ho che il numero 1 è in posizione corretta, e da lì in poi il programma non cambia più stato (rimane sempre con uguale=1).
Direi che potresti fare il contrario, ovvero supporre che siano tutti corretti (uguale=1 di partenza) ed impostare uguale=0 quando incontri il primo elemento diverso (a quel punto puoi anche uscire dal ciclo perché non serve in teoria controllare gli altri).
La funzione Acquisisci() non mi sembra fatta male, ho giusto qualche dubbio sul fflush(stdin) che non so quanto sia necessario.
Dunque, la funzione Casuale() potrebbe essere fatta meglio, perché IMHO fai troppi controlli, tuttavia per il momento se ti funziona lasciamola com'è...
Nella funzione Verifica() invece c'è qualcosa che non va, innanzitutto cosa vuoi verificare con quella funzione?
La presenza dei numeri o l'esatta posizione?
Poi quel j è una svista o vuoi farci qualcosa?
Al di là di questo, se consideriamo una situazione del genere:
computer: 1 2 3 4
utente: 1 6 7 8
Il tuo algoritmo mi direbbe che ho indovinato, quando invece non è vero.
Questo perché al primo passo ho che il numero 1 è in posizione corretta, e da lì in poi il programma non cambia più stato (rimane sempre con uguale=1).
Direi che potresti fare il contrario, ovvero supporre che siano tutti corretti (uguale=1 di partenza) ed impostare uguale=0 quando incontri il primo elemento diverso (a quel punto puoi anche uscire dal ciclo perché non serve in teoria controllare gli altri).
La funzione Acquisisci() non mi sembra fatta male, ho giusto qualche dubbio sul fflush(stdin) che non so quanto sia necessario.
Lo so.
Comunque era solo per iniziare, volevo intanto verificare se la sequenza dei numeri era stata indovinata
La j è l'indice dell'array casuale, ovviamente è dichiarata globalmente, credo vada bene, anche se forse serve qualche return.
Per il fflush(stdin) lo metto sempre, così ha detto il prof...
Comunque per il resto ok, devo modificarlo, magari ditemi come scrivereste voi il codice più o meno, grazie mille.
Il fflush(stdin) serve a forzare lo svuotamento del buffer di stdin, lo standard input, che è la tastiera.
Mi servì anche a me tempo fa, ma poi risolvetti ora non ricordo come.
Non è strettamente necessario.
Il Verifica() non va bene, per il semplice motivo che se ad esempio:
il 1° numero è uguale, la var uguali diventa 1
il 2° numero è diverso la var uguali che era 1, non varia. E proprio qui che devi fare un else in cui uguali diventa 0.
Di Casuale() inoltre devi tenere conto delle ipotesi che potrebbe capitare che il 1° numero sia uguale al 3° quindi deve ri-randomizzare.
Secondo me ti conviene fare tutte le condizioni con ordine ovvero:
Indici 0 - 1, 0 - 2, 0 - 3 , 1 - 2, 1 - 3, 2 - 3
Queste funzioni che dovrebbero restituire un valore intero, non hanno nessun return. A questo punto io ti consiglierei:
Nel Verifica() fare return 0; se le variabili sono diverse e la combinazione non è giusta, e ritornare 1 nel caso si trovi la giusta combinazione. In questo modo puoi facilmente gestire la vittoria.
Il fflush(stdin) serve a forzare lo svuotamento del buffer di stdin, lo standard input, che è la tastiera.
Mi servì anche a me tempo fa, ma poi risolvetti ora non ricordo come.
Non è strettamente necessario.
Il Verifica() non va bene, per il semplice motivo che se ad esempio:
il 1° numero è uguale, la var uguali diventa 1
il 2° numero è diverso la var uguali che era 1, non varia. E proprio qui che devi fare un else in cui uguali diventa 0.
Di Casuale() inoltre devi tenere conto delle ipotesi che potrebbe capitare che il 1° numero sia uguale al 3° quindi deve ri-randomizzare.
Secondo me ti conviene fare tutte le condizioni con ordine ovvero:
Indici 0 - 1, 0 - 2, 0 - 3 , 1 - 2, 1 - 3, 2 - 3
Queste funzioni che dovrebbero restituire un valore intero, non hanno nessun return. A questo punto io ti consiglierei:
Nel Verifica() fare return 0; se le variabili sono diverse e la combinazione non è giusta, e ritornare 1 nel caso si trovi la giusta combinazione. In questo modo puoi facilmente gestire la vittoria.
Grazie mille !
Ora sistemo, anche se mi manca parecchie cose ancora.
[..]
La j è l'indice dell'array casuale, ovviamente è dichiarata globalmente, credo vada bene, anche se forse serve qualche return.
La j nel corso del ciclo non varia, per cui non va bene per niente, significa che stai facendo il controllo sempre con lo stesso elemento :D.
Se vuoi controllare che i numeri siano nella stessa posizione ti basta usare solo l'indice i, scrivendo quel pezzo come:
if (num[i]==casuale[i]) ...
Per il fflush(stdin) lo metto sempre, così ha detto il prof...
Comunque per il resto ok, devo modificarlo, magari ditemi come scrivereste voi il codice più o meno, grazie mille.
Ok per il fflush.
Comunque se rileggi attentamente il mio post troverai che ho indicato come scriverei io la funzione Verifica ;).
Devi semplicmente invertire il controllo e partire dal presupposto che gli elementi dei due array siano tutti uguali.
Scorri l'array con il for e appena trovi un elemento diverso fai return 0;
Altrimenti se arrivi alla fine del ciclo significa che sono tutti uguali, quindi ritorni 1.
Non ti serve neanche usare altre variabili. In pratica posso dirti con certezza che te la cavi con 3 righe esatte di codice.
La j nel corso del ciclo non varia, per cui non va bene per niente, significa che stai facendo il controllo sempre con lo stesso elemento :D.
Se vuoi controllare che i numeri siano nella stessa posizione ti basta usare solo l'indice i, scrivendo quel pezzo come:
if (num[i]==casuale[i]) ...
Ok per il fflush.
Comunque se rileggi attentamente il mio post troverai che ho indicato come scriverei io la funzione Verifica ;).
Devi semplicmente invertire il controllo e partire dal presupposto che gli elementi dei due array siano tutti uguali.
Scorri l'array con il for e appena trovi un elemento diverso fai return 0;
Altrimenti se arrivi alla fine del ciclo significa che sono tutti uguali, quindi ritorni 1.
Non ti serve neanche usare altre variabili. In pratica posso dirti con certezza che te la cavi con 3 righe esatte di codice.
Ok, grazie mille, sei stato chiarissimo.
Adesso aggiorno il codice.
vBulletin® v3.6.4, Copyright ©2000-2025, Jelsoft Enterprises Ltd.