IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

 C Discussion :

Liste chainée & Erreur de segmentation


Sujet :

C

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre habitué
    Profil pro
    Inscrit en
    Février 2011
    Messages
    10
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2011
    Messages : 10
    Par défaut Liste chainée & Erreur de segmentation
    Bonsoir à tous,

    J'ai un devoir qui consiste à gérer un ensemble d'intervalles (des fonctions créées avant permettent de manipuler les intervalles mais là n'est pas la question ^^). Voilà les déclarations des types NOEUD, ENSEMBLE et INTERVALLE :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    typedef struct NOEUD
    {
      intervalle interv;
      struct NOEUD *suivant;
    } noeud;
     
    typedef noeud *ensemble;
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    typedef struct {
        int min;
        int max;
    } intervalle;
    Je dois ensuite créer une fonction d'en-tête (non modifiable), qui permet d'insérer dans un ensemble un intervalle, mais ces intervalles sont triés selon leur borne MIN :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    void inserer(ensemble * E, intervalle I)
    J'ai donc tenté de réaliser cette fonction mais lors de l'exécution (la fonction est appelée dans main() ), un message me dit "Erreur de segmentation".
    Voici mon 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
    void inserer(ensemble * E, intervalle I)
    {
      noeud *n = *E;
      noeud *tmp;
      while (n != NULL) {
        if (n == NULL) {
          tmp->interv = I;
          tmp->suivant = NULL;
          n = NULL;
        } else if (I.min > n->interv.min && n->suivant == NULL) {
          tmp->interv = n->interv;
          tmp->suivant->interv = I;
          tmp->suivant->suivant = NULL;
          n = NULL;
        } else if (I.min > n->interv.min && I.min < n->suivant->interv.min) {
          tmp->interv = n->interv;
          tmp->suivant->interv = I;
          tmp->suivant->suivant = n->suivant;
          n = NULL;
        } else if (I.min < n->interv.min) {
          tmp->interv = I;
          tmp->suivant = n;
          n = NULL;
        } else {
          tmp->interv = n->interv;
          n = n->suivant;
        }
      }
      *E = tmp;
    }
    Et la ligne permettant d'appeler cette fonction (I1 est un intervalle déjà défini) :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    inserer((ensemble *) e, I1);
    J'avais essayé de bidouiller avec des "malloc" mais sans succès...
    Si quelqu'un peut m'aider, j'écoute avec attention

  2. #2
    Membre Expert Avatar de Trademark
    Profil pro
    Inscrit en
    Février 2009
    Messages
    762
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2009
    Messages : 762
    Par défaut
    Plusieurs choses...

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
      while (n != NULL) {
        if (n == NULL) {
          tmp->interv = I;
          tmp->suivant = NULL;
          n = NULL;
        }
    Si n est différent de NULL alors il n'est pas égal à NULL... à méditer.

    Par contre l'erreur de segmentation provient surement du fait que :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    inserer((ensemble *) e, I1);
    n'est pas bon. Enfin ça dépend comment tu as déclaré e, mais si tu fais un cast je présume que c'est pour éviter un warning du compilo qui te dit que e n'est pas une adresse ou un truc comme ça... Si oui tu dois faire :

    Si c'est pas à cause de ça, c'est surement à cause de ça :

    que tu n'initialises jamais, donc en bref tu essayes de déréférencer une adresse qui n'est pas valide.

    Il faut savoir que l'erreur de segmentation t'indique que tu essayes d'accéder à une adresse non valide via '*' ou '->' (qui n'est autre que (*v).m).

    Tu t'es probablement embrouillé dans ton code car tu n'avais pas essayé de l'écrire correctement sur papier avant. Une fonction comme la tienne peut être réalisée en 5 lignes environ... (Indice : essaye de n'avoir une boucle while que d'une ou deux lignes).

  3. #3
    Inactif  


    Homme Profil pro
    Doctorant sécurité informatique — Diplômé master Droit/Économie/Gestion
    Inscrit en
    Décembre 2011
    Messages
    9 026
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 32
    Localisation : France, Loire (Rhône Alpes)

    Informations professionnelles :
    Activité : Doctorant sécurité informatique — Diplômé master Droit/Économie/Gestion
    Secteur : Enseignement

    Informations forums :
    Inscription : Décembre 2011
    Messages : 9 026
    Par défaut
    J'ai lu vite fait, mais il ne manquerait pas des malloc?

    Si tu n'utilise pas malloc, les ressources sont libérés à la fin de ta fonction d'où le segfault

  4. #4
    Expert confirmé
    Avatar de diogene
    Homme Profil pro
    Enseignant Chercheur
    Inscrit en
    Juin 2005
    Messages
    5 761
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Essonne (Île de France)

    Informations professionnelles :
    Activité : Enseignant Chercheur
    Secteur : Enseignement

    Informations forums :
    Inscription : Juin 2005
    Messages : 5 761
    Par défaut
    Pour préciser, dans
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
      noeud *tmp;
      while (n != NULL) {
        if (n == NULL) {
          tmp->interv = I
    ....
    La ligne 4 va planter : créer un pointeur sur noeud (tmp) ne crée pas le noeud. Il manque un
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    tmp = malloc(sizeof *tmp);
    pour le créer et assurer sa survie en sortie de fonction.

Discussions similaires

  1. Réponses: 7
    Dernier message: 21/11/2012, 12h40
  2. Réponses: 23
    Dernier message: 14/03/2009, 15h57
  3. Réponses: 5
    Dernier message: 04/11/2007, 13h39
  4. Fin de liste chainée, erreur
    Par faulk dans le forum C
    Réponses: 3
    Dernier message: 21/10/2006, 20h02
  5. Erreur de segmentation sur une chaine en récursif...
    Par laurent_ifips dans le forum C
    Réponses: 12
    Dernier message: 13/12/2005, 16h04

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo