Torna indietro   Hardware Upgrade Forum > Software > Programmazione

DJI RS 5: stabilizzazione e tracking intelligente per ogni videomaker
DJI RS 5: stabilizzazione e tracking intelligente per ogni videomaker
Analizziamo nel dettaglio DJI RS 5, l'ultimo arrivato della famiglia Ronin progettato per videomaker solisti e piccoli studi. Tra tracciamento intelligente migliorato e ricarica ultra rapida, scopriamo come questo gimbal eleva la qualità delle produzioni.
AMD Ryzen 7 9850X3D: Zen 5, 3D V-Cache e frequenze al top per il gaming
AMD Ryzen 7 9850X3D: Zen 5, 3D V-Cache e frequenze al top per il gaming
AMD Ryzen 7 9850X3D è la nuova CPU gaming di riferimento grazie alla 3D V-Cache di seconda generazione e frequenze fino a 5,6 GHz. Nei test offre prestazioni superiori a 9800X3D e 7800X3D, confermando la leadership AMD nel gaming su PC.
Le soluzioni FSP per il 2026: potenza e IA al centro
Le soluzioni FSP per il 2026: potenza e IA al centro
In occasione del Tech Tour 2025 della European Hardware Association abbiamo incontrato a Taiwan FSP, azienda impegnata nella produzione di alimentatori, chassis e soluzioni di raffreddamento tanto per clienti OEM come a proprio marchio. Potenze sempre più elevate negli alimentatori per far fronte alle necessità delle elaborazioni di intelligenza artificiale.
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 29-01-2017, 19:02   #1
thecarmy97
Junior Member
 
Iscritto dal: Jul 2014
Messaggi: 2
Problema con gioco di briscola in C++

Codice:
 #include <iostream>
#include <stdlib.h>
#include <ctime>

using namespace std;


struct carta{
char *seme;
int valore;
char *nome;
int punteggio;
};


char seme[4][20] = {"Mazze", "Spade", "Coppe","Denari"};
char nome[10][20] = {"Asso", "Due", "Tre", "Quattro", "Cinque", "Sei", "Sette", "Donna", "Cavallo", "Re"};
int valore[10] = {12, 2, 11, 4, 5, 6, 7, 8, 9, 10};
int punteggio[10] = {11, 0, 10, 0, 0, 0, 0, 2, 3, 4};


void crea_mazzo(carta mazzo[]){
    int c=0;
for(int i = 0; i<4; i++){
    for(int j = 0; j<10; j++){
        mazzo[c].seme = seme[i];
        mazzo[c].valore = valore[j];
        mazzo[c].punteggio = punteggio[j];
        mazzo[c].nome = nome[j];
        c++;
    }
}
}

void mischia_mazzo(carta mazzo[]){
int primacarta, secondacarta;
carta cartatemp;
srand((unsigned)time(NULL));
for(int i = 0; i<40; i++){
    primacarta = rand() % 40;
    secondacarta = rand() % 40;
    cartatemp = mazzo[primacarta];
    mazzo[primacarta] = mazzo[secondacarta];
    mazzo[secondacarta] = cartatemp;
}
}

carta crea_briscola(carta labriscola1, carta mazzo[]){
labriscola1 = mazzo[39];
return labriscola1;
}

int distribuisci_carte(carta mazzo[], carta manogioc[], carta manoia[]){
 int i, c1, c2;
    c1=0;
    c2=0;
    for(i = 0; i < 6; i++){
       if(i < 3){
      manogioc[c1++] = mazzo[i];
       }
       else{
        manoia[c2++] = mazzo[i];
       }
}
return 6;
}

void mostra_carte_gioc(carta manogioc[]){

for(int i=0; i<3; i++){
    if(manogioc[i].seme == nullptr)
        cout<<i<<". "<<endl;
    else
        cout<<i<<". "<<manogioc[i].nome<<" di "<<manogioc[i].seme<<endl;
}

}

int gioca_carta(carta manogioc[], carta campo[]){
int posizione_carta=0;

cout<<"Inserisci la posizione della carta che vuoi giocare: ";
cin>>posizione_carta;
cout<<endl;
while(posizione_carta > 2 || posizione_carta < 0 || manogioc[posizione_carta].seme==nullptr){
    cout<<"Seleziona una carta esistente! "<<endl;
    cout<<"Inserisci la posizione della carta che vuoi giocare: ";
    cin>>posizione_carta;
    cout<<endl;
}
    cout<<"Hai giocato la carta "<<manogioc[posizione_carta].nome<<" di "<<manogioc[posizione_carta].seme<<endl<<endl;
    campo[0] = manogioc[posizione_carta];
    return posizione_carta;
}

int gioca_ia(carta manoia[], carta campo[]){
    srand((unsigned)time(NULL));
   int posizione_cartaia = rand() % 3;
   while(manoia[posizione_cartaia].nome==nullptr){
        posizione_cartaia = rand() % 3;
   }
   cout<<"L'IA ha giocato la carta: "<<manoia[posizione_cartaia].nome<<" di "<<manoia[posizione_cartaia].seme<<endl;
    campo[1] = manoia[posizione_cartaia];
    return posizione_cartaia;
}

int pescacarta(carta mazzo[], carta primamano[], carta secondamano[], int posizionedeck, int primapos, int secondapos){
carta cartavuota = {nullptr};
if(posizionedeck < 40){
    primamano[primapos] = mazzo[posizionedeck];
    secondamano[secondapos] = mazzo[posizionedeck+1];
}
    else{
        primamano[primapos] = cartavuota;
        secondamano[secondapos] = cartavuota;
    }
return posizionedeck + 2;
}


int funzione_presagioc (carta primamano[], carta secondamano[], int primapos, int secondapos, carta briscola, int &presa){
if(primamano[primapos].valore >= secondamano[secondapos].valore && secondamano[secondapos].seme != briscola.seme)
   return presa = 1;

    else if(primamano[primapos].valore < secondamano[secondapos].valore && primamano[primapos].seme != secondamano[secondapos].seme)
      return  presa = 1;

    else if(primamano[primapos].seme == briscola.seme && secondamano[secondapos].seme != briscola.seme)
   return presa= 1;

else if(primamano[primapos].seme == briscola.seme && secondamano[secondapos].seme == briscola.seme && primamano[primapos].valore > secondamano[secondapos].valore)
 return presa= 1;


else  return presa = 0;
}

int funzione_presaia (carta primamano[], carta secondamano[], int primapos, int secondapos, carta briscola, int &presa){
if(primamano[primapos].valore >= secondamano[secondapos].valore && secondamano[secondapos].seme != briscola.seme)
   return presa = 0;

    else if(primamano[primapos].valore < secondamano[secondapos].valore && primamano[primapos].seme != secondamano[secondapos].seme)
      return  presa = 0;

    else if(primamano[primapos].seme == briscola.seme && secondamano[secondapos].seme != briscola.seme)
   return presa= 0;

else if(primamano[primapos].seme == briscola.seme && secondamano[secondapos].seme == briscola.seme && primamano[primapos].valore > secondamano[secondapos].valore)
 return presa= 0;


else  return presa = 1;

}

int main(){
carta mazzo[40];
int mazzogioc[40];
int mazzoia[40];
carta mano_gioc[3]={nullptr};
carta campo[2];
carta mano_ia[3]={nullptr};
int manofinale=0;
int pos_gioc;
int pos_ia;
int presa=1;
int c1 = 0;
int c2 = 0;
int puntigioc=0;
int puntiia=0;

carta labriscola;
crea_mazzo(mazzo);
int posizione_mazzo;
mischia_mazzo(mazzo);

cout<<"Benvenuto a Briscola!"<<endl<<endl;
system("PAUSE");
cout<<endl;
labriscola = crea_briscola(labriscola, mazzo);
posizione_mazzo = distribuisci_carte(mazzo, mano_gioc, mano_ia);
while(posizione_mazzo < 46){
system("CLS");
cout<<"La briscola in questa partita e': "<<labriscola.nome<<" di "<<labriscola.seme<<endl<<endl;
if(presa == 1){
cout<<"La tua mano e': "<<endl;
cout<<endl;
mostra_carte_gioc(mano_gioc);
cout<<endl;
pos_gioc = gioca_carta(mano_gioc, campo);
pos_ia = gioca_ia(mano_ia, campo);
funzione_presagioc(mano_gioc, mano_ia, pos_gioc, pos_ia, labriscola, presa);
posizione_mazzo = pescacarta(mazzo, mano_gioc, mano_ia, posizione_mazzo, pos_gioc, pos_ia);
mazzogioc[c1] = campo[0].punteggio;
mazzogioc[c1+1] = campo[1].punteggio;
c1+=2;
}
else if(presa == 0){
cout<<"La tua mano e': "<<endl;
cout<<endl;
mostra_carte_gioc(mano_gioc);
cout<<endl;
gioca_ia(mano_ia, campo);
gioca_carta(mano_gioc, campo);
cout<<endl;
funzione_presaia(mano_ia, mano_gioc, pos_ia, pos_gioc, labriscola, presa);
posizione_mazzo = pescacarta(mazzo, mano_ia, mano_gioc, posizione_mazzo, pos_ia, pos_gioc);
mazzoia[c2] = campo[0].punteggio;
mazzoia[c2+1] = campo[1].punteggio;
c2+=2;
}

if(presa == 1)
    cout<<"Hai preso la mano!"<<endl;
else if(presa == 0)
    cout<<"L'IA ha preso la mano!"<<endl;
system("PAUSE");
}


for(int i = 0; i<c1; i++){
    puntigioc+=mazzogioc[i];
}

for(int j = 0; j<c2; j++){
    puntiia+=mazzoia[j];
  }



cout<<"Hai totalizzato "<<puntigioc<<" ."<<endl;
cout<<"L'IA ha totalizzato "<<puntiia<<" ."<<endl;
if(puntigioc > puntiia)
    cout<<"HAI VINTO!"<<endl;
else if(puntiia > puntigioc)
    cout<<"HAI PERSO!"<<endl;
    else if(puntiia == puntigioc)
        cout<<"HAI PAREGGIATO!";


return 0;
system("PAUSE");
cout<<"\n\n";
}

Salve, premetto che non sono molto esperto del linguaggio. Ho scritto questo programma che simula la briscola per un esame universitario. Il compilatore non mi da errori, ma il gioco soffre di qualche problema: il conteggio dei voti non è sempre perfetto, e sopratutto la pesca ad ogni turno è spesso buggata, e mi vengono pescate carte nella posizione sbagliata. Qualcuno che può eseguire il programma e mi dia una mano? Ve ne sarei molto grato, vi ringrazio.
thecarmy97 è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


DJI RS 5: stabilizzazione e tracking intelligente per ogni videomaker DJI RS 5: stabilizzazione e tracking intelligent...
AMD Ryzen 7 9850X3D: Zen 5, 3D V-Cache e frequenze al top per il gaming AMD Ryzen 7 9850X3D: Zen 5, 3D V-Cache e frequen...
Le soluzioni FSP per il 2026: potenza e IA al centro Le soluzioni FSP per il 2026: potenza e IA al ce...
AWS annuncia European Sovereign Cloud, il cloud sovrano per convincere l'Europa AWS annuncia European Sovereign Cloud, il cloud ...
Redmi Note 15 Pro+ 5G: autonomia monstre e display luminoso, ma il prezzo è alto Redmi Note 15 Pro+ 5G: autonomia monstre e displ...
Il satellite spia russo Olymp-1 si &egra...
Rocket Lab prosegue l'assemblaggio del n...
Il Wet Dress Rehearsal della missione Ar...
31,4 Tbps: Aisuru sfonda il suo stesso r...
Giocattoli AI, una falla espone oltre 50...
OPPO Reno15 in viaggio con Gaia Gozzi: i...
Nuove revisioni per Abarth 600e: arrivan...
Intelligenza artificiale, re-training e ...
LG presenta a ISE 2026 la nuova serie di...
Alienware: disponibile in Italia il nuov...
Arrivano le bodycam sui treni di Ferrovi...
Nike taglia 775 posti negli USA: l'autom...
Crimson Desert si mostra in un nuovo gam...
Addio transistor? Questo dispositivo usa...
Jensen Huang: le fabbriche negli Stati U...
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: 23:13.


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