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 :

Détail d'un bout de code


Sujet :

C

  1. #1
    Membre actif
    Homme Profil pro
    Étudiant
    Inscrit en
    Décembre 2012
    Messages
    21
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Étudiant
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Décembre 2012
    Messages : 21
    Par défaut Détail d'un bout de code
    Salut à tous,

    J'ai sous les yeux un bout de code, que j'aimerais être sur de comprendre :

    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
     
    void sup_elem(etudiant *elem_supp)
    {
      int num;
      etudiant *succ, *prec;
     
      succ = elem_supp->succ;
      prec = elem_supp->prec;
     
    if(succ != NULL) //il y a ue table suivante dans la table
        {
            succ->prec = prec;
        }
     
        if(prec != NULL) //
        {
            prec->succ = succ;
        }
     
        else //Il s'agit du premier de la liste
        {
            num = hash(elem_supp->nom_etud);
            table_hash[num] = succ;
        }
     
    }
    Du coup, si je comprends bien, ça veut dire que la fonction prend en paramètre une structure « etudiant », il y a une variable « num » et 2 variables de pointeur de type « etudiant » qui sont « succ » et « prec ».

    Si « succ » n'est pas égal à NULL, alors le « succ » du « prec » sera égal au « prec » ;
    Si « prec » n'est pas égal à NULL, alors le « prec » du « suiv » sera égal au « suiv » ;

    … sinon on instancie la variable « num » avec le nom de l’étudiant et la « table_hash ». Enfin, le nom de la table sera instancié au « suiv ».

    J'ai un doute quand la compréhension de l'explication.

    Merci de l'aide

  2. #2
    Modérateur

    Avatar de Bktero
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Juin 2009
    Messages
    4 492
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 37
    Localisation : France, Loire Atlantique (Pays de la Loire)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels

    Informations forums :
    Inscription : Juin 2009
    Messages : 4 492
    Billets dans le blog
    1
    Par défaut
    La variable suiv n'est pas déclarée ?
    Quel est l'intérêt des variables succ et prec ?

    La fonction prend en paramètre un pointeur vers une structure etudiant (il y a une étoile).

    Je ne comprends pas trop à quoi sert la fonction, mais le 2e if ne devrait-il pas plutôt être un else if ?

    Où as-tu trouvé cette fonction, qu'est-elle censée faire ?

  3. #3
    Membre actif
    Homme Profil pro
    Étudiant
    Inscrit en
    Décembre 2012
    Messages
    21
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Étudiant
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Décembre 2012
    Messages : 21
    Par défaut
    Et bien elle est censé supprimer un étudiant dans une table de Hash

  4. #4
    Modérateur

    Avatar de Bktero
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Juin 2009
    Messages
    4 492
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 37
    Localisation : France, Loire Atlantique (Pays de la Loire)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels

    Informations forums :
    Inscription : Juin 2009
    Messages : 4 492
    Billets dans le blog
    1
    Par défaut
    Je lis un peu la partie sur les tables de hachage de la Glib, dans ce livre.

    Une table de hachage est un tableau de listes. Si tu souhaites supprimer un élément, il faut donc déterminer quand quelle liste il pourrait être et regarder s'il s'y trouve, non ?

    Or, j'ai ici l'impression que ta fonction se sert du contenu dans un élément pour faire la suppression. Les noms de la fonction / du paramètre / des champs de la structure ne sont pas très explicites et significatifs. Pourrais-tu notamment nous donner la définition de la structure etudiant stp ?

  5. #5
    Membre actif
    Homme Profil pro
    Étudiant
    Inscrit en
    Décembre 2012
    Messages
    21
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Étudiant
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Décembre 2012
    Messages : 21
    Par défaut
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    struct table{
     
        struct table *succ;
     
        char nomEtud[TAILLE_NOM]; 
     
        struct table *prec; 
    };
     
    typedef struct table table_t;
    Bien sur voila

  6. #6
    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
    Bonjour,

    Il me semble que ta structure "table" devrait plus ressembler à cela :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    typdef struct
    {
           ListEtudiant m_liste[VAL_MAX_HASH];
     
    }MonType;
    Avec ListEtudiant une liste d'étudiant.

  7. #7
    Expert confirmé
    Avatar de fred1599
    Homme Profil pro
    Lead Dev Python
    Inscrit en
    Juillet 2006
    Messages
    4 044
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Meurthe et Moselle (Lorraine)

    Informations professionnelles :
    Activité : Lead Dev Python
    Secteur : Arts - Culture

    Informations forums :
    Inscription : Juillet 2006
    Messages : 4 044
    Par défaut
    Et bien elle est censé supprimer un étudiant dans une table de Hash
    Excusez moi, je vais parler de mon expérience en python, mais une table de hachage est composée d'une clé et de sa valeur, pareil en C, non?

    Où est la clé et la valeur dans le cas où c'est oui?

Discussions similaires

  1. la sauvegarde des bouts de code ?
    Par blackhorus dans le forum Autres éditeurs
    Réponses: 2
    Dernier message: 02/10/2005, 13h34
  2. [XML][XSL] déplacer bout de code XML
    Par majanissa dans le forum XSL/XSLT/XPATH
    Réponses: 8
    Dernier message: 14/09/2005, 17h17
  3. Besoin d'explications sur un bout de code
    Par zizitop dans le forum C
    Réponses: 7
    Dernier message: 26/04/2005, 14h51
  4. bout de code à dechifrer svp
    Par bball dans le forum C
    Réponses: 32
    Dernier message: 20/01/2005, 23h23

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