Rechercher : dans
Par :

C++ erreur de segmentation

Dernière réponse le 19 jan 2005 à 00:43:36 Pierre, le 18 jan 2005 à 20:53:09 
 Signaler ce message aux modérateurs

Bonjour,
je me suis fait un ptit programme :
--------------
int main()
{
int nbeleves;
int nbnotes;
float total = 0;
float moy;

cout << "Combien avez-vous d'élèves ?\n";
cin >> nbeleves;
cout << "\nCombien y a t-il de notes par élève ?\n";
cin >> nbnotes;

struct eleve
{
float note[];
string prenom, nom;
};
eleve eleve_no[40];

cout << "\n\nOK ...\n";

for(int i=0;i<nbeleves;i++)
{
cout << "\nEntrez le prénom de l'élève " << i+1 << " :\n";
cin >> eleve_no[i].prenom;
cout << "\n\nEntrez le nom de cet élève :\n";
cin >> eleve_no[i].nom;

for(int a=0;a<nbnotes;a++)
{
cout << "\nEntrez la note " << a+1 << " :\n";
cin >> eleve_no[i].note[a];
}
return 0;
}
}
---------------

Il marche parfaitement, mais à la fin il me dis "erreur de segmentation ".
Je ne vois pas pourquoi ?

Meilleures réponses pour « C++ erreur de segmentation » dans :
[Langage C] C/C++ Erreur de segmentation Voir Qu'est ce qu'une erreur de segmentation Vous êtes en train de développer une application sous Linux en C/C++. Tout va bien, ça compile, les oiseaux chantent. Donc vous lancez votre application pour la tester. Et vous obtenez l'un de ces deux...
Introduction à la STL en C++ (standard template library) VoirIntroduction Principales classes de la STL std::pair std::list std::vector std::set std::map Les iterators iterator et const_iterator reverse_iterator et const_reverse_iterator Les algorithmes ...
La compilation et les modules en C et en C++ VoirCet article a pour vocation d'introduire les notions de bases de la compilation en C et en C++ et de la programmation modulaire. Il permet de mieux comprendre les messages d'erreur du compilateur. Les notions abordées ici sont indépendantes du...

1

stef, le 18 jan 2005 à 21:18:05

Salut Pierre,
Quand tu as le segmentation fault quelles sont les valeurs de nbeleves et nbnotes?

Selon ces valeurs tes boucles for sont mal construites car tu incrémentes les variables de tes boucles for (i et a) 2 fois et tu peux donc demander à écrire en dehors de tes tableaux.

stef

Répondre à stef

2

stef, le 18 jan 2005 à 21:44:30

Pierre,

petite correction à mon dernier mesasge, tu incrémentes bien qu'un fois néanmoins si nbeleves> 40 tu écris hors du tableau.

De plus quelle valeur mets tu dans la struct pour note[] ???

Stef

Répondre à stef

3

eric, le 18 jan 2005 à 21:58:36

Bonjours,

Je pense que cela vient du fait que tu ne définis pas un nombre max de notes par élève.

Par ailleurs ton "return 0;" est assez curieusement placé.

a+

eric

Répondre à eric

4

Pierre, le 18 jan 2005 à 22:03:31

Merci pour vos réponse, pour le "return 0" c ke javais pas copier mon message en eniter dc je l'ai rajouté sans faire attention .

Répondre à Pierre

5

Pierre, le 18 jan 2005 à 22:08:38

Je n'écris pas en dehors du tableau, j'ai mis que 2 élève et une note mais il y a toujours le meme problème et ce n'est pas au niveau de
"float note[];" .
Je ne comprend pas .

Répondre à Pierre

6

stef, le 18 jan 2005 à 22:12:02

J'ai essayé ca chez moi et ca fonctionne bien...

struct eleve {
float *note;
string prenom, nom;
};
eleve eleve_no[40];

int main() {
int nbeleves;
int nbnotes;
float total = 0;

cout << "Combien avez-vous d'élèves ?\n";
cin >> nbeleves;
cout << "\nCombien y a t-il de notes par élève ?\n";
cin >> nbnotes;

for (int j=0; j<40; j++) {
eleve_no[j].note = new float(nbnotes);
}

cout << "\n\nOK ...\n";

for(int i=0;i<nbeleves;i++) {
cout << "\nEntrez le prénom de l'élève " << i+1 << " :\n";
cin >> eleve_no[i].prenom;
cout << "\n\nEntrez le nom de cet élève :\n";
cin >> eleve_no[i].nom;

for(int a=0;a<nbnotes;a++) {
cout << "\nEntrez la note " << a+1 << " :\n";
cin >> eleve_no[i].note[a];
}
}
return 0;
}

Répondre à stef

7

 Jon301, le 19 jan 2005 à 00:43:36

Pierre,
Lorsque tu as un segmentation fault, c'est souvent une erreur d'indice dans un tableau

Ici, tu as saisi le nombre de note par eleve, mais dans ta structure tu n'as pas donné de taille pour le tableau de note.
(float note[]; n'est pas correct).

Etant donné que la taille d'un tableau doit être une constante et que ca fait pas propre de faire une saisie de la taille de cette manière,

il faudrait que tu déclares un pointeur et que tu alloue dynamiquement un tableau de nbnotes

float* note;
note = new float[nbnote];

en gros, comme ce qu'a fait stef ci dessus

voila.

Jon

Répondre à Jon301