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 :

suppression d'un noeud d'un arbre


Sujet :

C

  1. #1
    Membre du Club
    Inscrit en
    Novembre 2007
    Messages
    56
    Détails du profil
    Informations forums :
    Inscription : Novembre 2007
    Messages : 56
    Points : 46
    Points
    46
    Par défaut suppression d'un noeud d'un arbre
    Bonjour,
    J'ai un petit problème j'ai une arbre normale et je veux supprimer un noeud je ne sais pas comment faire et si ce noeud contient des fils est ce que je supprime aussi ces fils répondez moi vite stp

  2. #2
    Membre émérite
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Octobre 2008
    Messages
    1 515
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 45
    Localisation : France

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

    Informations forums :
    Inscription : Octobre 2008
    Messages : 1 515
    Points : 2 505
    Points
    2 505
    Par défaut
    Citation Envoyé par kaiseresis Voir le message
    Bonjour,
    J'ai un petit problème j'ai une arbre normale et je veux supprimer un noeud je ne sais pas comment faire
    Ca dépend de la structure de ton arbre. Donne nous la définition d'un noeud de ton arbre. Sans ça on ne peut rien faire.
    Citation Envoyé par kaiseresis Voir le message
    et si ce noeud contient des fils est ce que je supprime aussi ces fils répondez moi vite stp
    Ca dépend de ce que tu veux faire, toi seul à la réponse à cette question.

  3. #3
    Membre du Club
    Inscrit en
    Novembre 2007
    Messages
    56
    Détails du profil
    Informations forums :
    Inscription : Novembre 2007
    Messages : 56
    Points : 46
    Points
    46
    Par défaut
    voila la structure de mon arbre
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    struct arbre{
    DATA *d;
    struct arbre *fils;
    struct arbre *frere;
    }
    en faite la question et de supprimmer les noeuds ayant un d> valeur

  4. #4
    Membre du Club
    Inscrit en
    Novembre 2007
    Messages
    56
    Détails du profil
    Informations forums :
    Inscription : Novembre 2007
    Messages : 56
    Points : 46
    Points
    46
    Par défaut
    et si je supprime un noeud pere alors qu'est ce que je doit faire avec ces fils

  5. #5
    Membre émérite
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Octobre 2008
    Messages
    1 515
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 45
    Localisation : France

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

    Informations forums :
    Inscription : Octobre 2008
    Messages : 1 515
    Points : 2 505
    Points
    2 505
    Par défaut
    Citation Envoyé par kaiseresis Voir le message
    et si je supprime un noeud pere alors qu'est ce que je doit faire avec ces fils
    Ca dépend de ce que tu veux faire de ton arbre, comme je l'ai déjà dit. On ne peux pas décider à ta place. Tu peux soit décider de supprimer toute la branche sous le noeud que tu supprime, soit décider de supprimer juste le noeud et de "greffer" la branche coupée sous le père du noeud que tu viens de supprimer.

    Une fois que tu as décidé, fait un dessin et voit quels pointeurs tu dois mettre à jour quand tu veux supprimer un noeud. Tu verra que selon les cas il faut updater un pointeur soit dans le noeud père (si le noeud à supprimer et le premier de la liste), soit dand le noeud frère.

    Et là tu risque d'avoir un problème, car avec tes structures tu ne peux connaitre directement ni le noeud père, ni le noeud frère directement à partir d'un noeud donné. Mais en général ce n'est pas un problème, car la suppression d'un noeud se fait lors du parcours de l'arbre. Et dans ce cas tu peux te "souvenir" de quel était le noeud parent ou le noeud frère.

  6. #6
    Expert éminent sénior
    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
    Points : 13 926
    Points
    13 926
    Par défaut
    Citation Envoyé par kaiseresis Voir le message
    voila la structure de mon arbre
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    struct arbre{
    DATA *d;
    struct arbre *fils;
    struct arbre *frere;
    }
    en faite la question et de supprimmer les noeuds ayant un d> valeur
    Est-ce que ton arbre a la structure d'un arbre binaire de recherche où, pour chaque noeud (dont la valeur de d sera notée ici dn), tous les noeuds du sous arbre gauche (ou droit) ont un d < dn et ceux du sous arbre droit (ou gauche) un d > dn ?
    Publication : Concepts en C

    Mon avatar : Glenn Gould

    --------------------------------------------------------------------------
    Une réponse vous a été utile ? Remerciez son auteur en cliquant le pouce vert !

Discussions similaires

  1. Suppression d'un noeud dans un arbre
    Par Amokrane dans le forum C++
    Réponses: 2
    Dernier message: 06/01/2006, 23h12
  2. Réponses: 3
    Dernier message: 31/12/2005, 12h30
  3. Déplacer un noeud dans un arbre
    Par BigBenQ dans le forum C++Builder
    Réponses: 2
    Dernier message: 10/10/2005, 15h16
  4. [VB.NET] [XML] Suppression d'un noeud dans un fichier XML
    Par Hoegaarden dans le forum Windows Forms
    Réponses: 2
    Dernier message: 24/09/2004, 11h24
  5. [DOM] suppression d'un noeud fils xml en JAVA
    Par alexandre54 dans le forum Format d'échange (XML, JSON...)
    Réponses: 5
    Dernier message: 20/03/2003, 09h44

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