1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138
|
#include <assert.h>
#include <stdlib.h>
#include <stdio.h>
#include "carte.h"
#include "fonctions.h"
/* La première carte de chaque table sert de compteur de carte dans
la couleur via son élément 'rang' */
struct Carte trefle[14];
struct Carte coeur[14];
struct Carte pique[14];
struct Carte carreau[14];
struct Carte suites[12];
struct Carte groups[12];
struct Carte nulles[12];
struct Carte donne[12]={{0,10,' ',0},{1,7,'P',0},{2,5,'P',0},{3,6,'P',0},{4,7,'C',0},{5,5,'C',0},
{6,7,'K',0},{7,8,'K',0},{8,10,'K',0},{9,7,'T',0},{10,12,'C',0},{11,0,' ',0}};
struct Carte **brelanCarre[] = {NULL,NULL,NULL};
struct Carte bestHand[12];
int defaultBest=500,nbMains;
int totaux[14];// comptabilisation des brelans et carrés
int main(void) {
while(1) {
setMain_1(0);
return 0;
}
}
int checkEntry(int r,char c) {
if((getColor(c))[r].rang == 0) return 0;
else return 1;
}
void setMain_1(int level) {
fprintf(stdout,"\nentre dans setMain() ...");
nouvelleMain(level);
setGroup(carreau,trefle,coeur,pique);
setSuite(coeur);
setSuite(trefle);
setSuite(carreau);
setSuite(pique);
setNulle(coeur,carreau,trefle,pique);
fprintf(stdout,"\nsort de setMain().");
}
void nouvelleMain(int level) {
int i;
fprintf(stdout,"\nentre dans nouvelleMain() ...");
for(i=0;i<12;i++) {
suites[i].rang=0;suites[i].color=' ';suites[i].used=0;
if(groups[i].used == level) {//on efface les carte du niveau uniquement
groups[i].rang=0;
groups[i].color=' ';
groups[i].used=0;
}
nulles[i].rang=0;nulles[i].color=' ';nulles[i].used=0;
}
for(i=1;i<=donne[0].rang;i++) {
if(((donne+i)->used > 0) && ((donne+i)->used < level)) continue;
(donne + i)->used = 0;
rangeCarte(donne+i);
totaux[(donne+i)->rang] += 1;
}
fprintf(stdout,"\nsort de nouvelleMain().");
}
void rangeCarte(struct Carte *c) {
fprintf(stdout,"\nentre dans rangeCarte() ...");
assert(c != NULL);
copy(c,getColor(c->color));
fprintf(stdout,"\nsort de rangeCarte().");
}
struct Carte * getColor(char c) {
fprintf(stdout,"\nentre dans getColor() ...");
switch(c) {
case 'P' :
fprintf(stdout,"\nsort de getColor().");
return pique;
case 'C' :
fprintf(stdout,"\nsort de getColor().");
return coeur;
case 'K' :
fprintf(stdout,"\nsort de getColor().");
return carreau;
case 'T' :
fprintf(stdout,"\nsort de getColor().");
return trefle;
default :
fprintf(stderr,"bad color '%c' !!",c);
exit(EXIT_FAILURE);
}
}
int evalLowCost(void) {
int i,valeur=0;
for(i=nulles[0].rang;i>0;i--) {
if(nulles[i].rang > 9) valeur += 10;
else valeur += nulles[i].rang;
}
return valeur;
}
void setGroup(struct Carte *t1,struct Carte *t2,struct Carte *t3,struct Carte *t4) {
int i,count=0;
fprintf(stdout,"\nentre dans setGroups() ...");
for(i=1;i<14;i++) {
if(totaux[i] == 3) {
if((t1+i)->rang) {
//(t1+i)->used = 2;
totaux[i]--;t1->rang--;
copyKill(t1+i,groups);
}
if((t2+i)->rang) {
//(t2+i)->used = 2;
totaux[i]--;t2->rang--;
copyKill(t2+i,groups);
}
if((t3+i)->rang) {
//(t3+i)->used = 2;
totaux[i]--;t3->rang--;
copyKill(t3+i,groups);
}
if((t4+i)->rang) {
//(t4+i)->used = 2;
totaux[i]--;t4->rang--;
copyKill(t4+i,groups);
}
}
else if(totaux[i] == 4) {
assert(count < 2);// Impossible de posséder plus de 2 carrés parmi 10 cartes
brelanCarre[count] = carreAnalysis(i);
count++;
}
}
if(count) traiterCarre(0);
fprintf(stdout,"\nsort de setGroups().");
} |
Partager