Bonjour à tous ;
voici le code :
Code : Sélectionner tout - Visualiser dans une fenêtre à part
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().");
}
Le programme compile sans erreur.
Le code de setMain_1() s'exécute ainsi que celui de nouvelleMain() ,puis rangeCarte() getColor() et copy() 10 fois ; alors l'exécution sort de
nouvelleMain() comme l'attestent les fprintf() disséminés dans les fonctions. Ensuite, le programme s'arrête et s'affiche un : Segmentation fault: 11
Est ce qu'on peut m'expliquer ce qu'il se passe exactement ...