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 :

Créer un arbre récursivement


Sujet :

C

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre averti
    Femme Profil pro
    Étudiant
    Inscrit en
    Avril 2017
    Messages
    15
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Âge : 28
    Localisation : France, Bas Rhin (Alsace)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Avril 2017
    Messages : 15
    Par défaut Créer un arbre récursivement
    Bonjour,
    je cherche à créer un arbre en rajoutant un élément à chaque tour de ma boucle. Le problème que je rencontre est que je n'arrive pas à remonter dans mon arbre pour rajouter certaines valeurs.
    Je pense que la conception de ma fonction qui ajoute l'élément n'est pas bonne.
    Voici une partie de 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
    31
    32
    33
    34
    35
    36
    37
    38
    39
     
    //ma structure
    typedef struct s_noeud {
    	char *op;
    	double nb;
    	struct s_noeud *fg,*fd;
    }noeud,*arbre;
     
    //fonction qui ajoute l'élément
    arbre enrac(arbre a,char *x)
    {
    	if (a->op==NULL)
    	{
    		a->op=x;
    		a->fg=NULL;
    		a->fd=NULL;
    		return a;
    	}
     
    	if (a->fg==NULL)
    	{
    		a->fg=enrac(a->fg,x);
    		return a->fg;
    	}
     
    	if( a->fd==NULL)
    	{
    		a->fd=enrac(a->fd,x);
    		return a;
    	}
     
    }
     
    //la boucle qui me permet de créer l'arbre
    while( bout != NULL )
    {
              a=enrac(a,bout);
    	bout = strtok(NULL, espace);
    }
    Merci d'avance pour votre aide

  2. #2
    Membre Expert
    Inscrit en
    Mars 2005
    Messages
    1 431
    Détails du profil
    Informations forums :
    Inscription : Mars 2005
    Messages : 1 431
    Par défaut
    Ton algorithme est faux, ou plus exactement mal implémenté. Que se passe-t-il dans la fonction enrac lorsqu'aucune des trois conditions testées n'est vérifiée ?

    Peux-tu déjà nous décrire ton algo en français (pas en C) ?

  3. #3
    Expert éminent
    Avatar de Médinoc
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Septembre 2005
    Messages
    27 395
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 41
    Localisation : France

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Septembre 2005
    Messages : 27 395
    Par défaut
    À aucun moment tu ne gères le cas où a est NULL, alors que tu fais des appels où c'est forcément le cas!
    SVP, pas de questions techniques par MP. Surtout si je ne vous ai jamais parlé avant.

    "Aw, come on, who would be so stupid as to insert a cast to make an error go away without actually fixing the error?"
    Apparently everyone.
    -- Raymond Chen.
    Traduction obligatoire: "Oh, voyons, qui serait assez stupide pour mettre un cast pour faire disparaitre un message d'erreur sans vraiment corriger l'erreur?" - Apparemment, tout le monde. -- Raymond Chen.

  4. #4
    Membre averti
    Femme Profil pro
    Étudiant
    Inscrit en
    Avril 2017
    Messages
    15
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Âge : 28
    Localisation : France, Bas Rhin (Alsace)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Avril 2017
    Messages : 15
    Par défaut
    Citation Envoyé par Matt_Houston Voir le message
    Ton algorithme est faux, ou plus exactement mal implémenté. Que se passe-t-il dans la fonction enrac lorsqu'aucune des trois conditions testées n'est vérifiée ?
    Je pense que quand aucune des conditions n'est vérifiée, il faudrait avancer dans l'arbre et faire a=a->fg ?

    Citation Envoyé par Matt_Houston Voir le message
    Peux-tu déjà nous décrire ton algo en français (pas en C) ?
    bout peut avoir 3 valeurs différentes et suivant les valeurs, il va soit constituer une feuille, soit un noeud avec deux fils, soit un noeud avec 1 seul fils gauche.
    Je pensais renvoyer avec enrac le noeud où je rajouterai au prochain appel récursif, mais je n'arrive pas à remonter dans mon arbre de cette manière.

    Exemple pour mieux me faire comprendre :
    bout prend les valeurs :
    bout=1;
    -> créer noeud1 avec fg et fd
    bout=1
    -> créer noeud2 à partir de fg et faire 2 branches (comme précédement)
    bout=3
    ->créer feuille à partir de fg du noeud2
    bout=3
    ->créer feuille à partir de fd du noeud2
    bout=3
    ->créer feuille à partir de fd du noeud1 (je ne vois pas comment je pourrais remonter jusque là)

    Pour faire simple, si je tape '+ * 1 2 3'
    Nom : arbr.png
Affichages : 303
Taille : 4,6 Ko

  5. #5
    Membre prolifique
    Avatar de Sve@r
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Février 2006
    Messages
    12 835
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Oise (Picardie)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : Aéronautique - Marine - Espace - Armement

    Informations forums :
    Inscription : Février 2006
    Messages : 12 835
    Billets dans le blog
    1
    Par défaut
    Citation Envoyé par KiitKaate Voir le message
    Pour faire simple, si je tape '+ * 1 2 3'
    Nom : arbr.png
Affichages : 303
Taille : 4,6 Ko
    Bonjour

    Ton dessin est une illustration de l'opération "1 * 2 + 3". J'aurais plutôt tendance alors à penser que c'est dans cet ordre qu'on devrait taper cette expression non ??? Surtout que l'algorithme pour la lire et la traiter (en respectant les priorités) existe déjà (Backus-Naur Form) et a été discuté ici.

    En revanche, si on entre "+ * 1 2 3" mais qu'on la lit en partant de la fin pour revenir au début, alors cela correspond à une "Polonaise Inversée" mais qui n'a pas besoin d'arbre pour être traitée car ça se gère avec une simple pile
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    Pour chaque entrée, faire
        si entrée est chiffre alors empilement
        sinon
             dépiler 2 derniers chiffres
             calculer l'opération avec l'entrée comme opérateur
             empiler le résultat
        fin si
    fin faire
    Et ça marche aussi si on l'entre ainsi: "+ 3 * 2 1" (toujours en partant de la fin vers le début)
    Mon Tutoriel sur la programmation «Python»
    Mon Tutoriel sur la programmation «Shell»
    Sinon il y en a pleins d'autres. N'oubliez pas non plus les différentes faq disponibles sur ce site
    Et on poste ses codes entre balises [code] et [/code]

  6. #6
    Membre averti
    Femme Profil pro
    Étudiant
    Inscrit en
    Avril 2017
    Messages
    15
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Âge : 28
    Localisation : France, Bas Rhin (Alsace)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Avril 2017
    Messages : 15
    Par défaut
    Citation Envoyé par Sve@r Voir le message
    Bonjour

    Ton dessin est une illustration de l'opération "1 * 2 + 3". J'aurais plutôt tendance alors à penser que c'est dans cet ordre qu'on devrait taper cette expression non ??? Surtout que l'algorithme pour la lire et la traiter (en respectant les priorités) existe déjà (Backus-Naur Form) et a été discuté ici.

    En revanche, si on entre "+ * 1 2 3" mais qu'on la lit en partant de la fin pour revenir au début, alors cela correspond à une "Polonaise Inversée" mais qui n'a pas besoin d'arbre pour être traitée car ça se gère avec une simple pile
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    Pour chaque entrée, faire
        si entrée est chiffre alors empilement
        sinon
             dépiler 2 derniers chiffres
             calculer l'opération avec l'entrée comme opérateur
             empiler le résultat
        fin si
    fin faire
    Et ça marche aussi si on l'entre ainsi: "+ 3 * 2 1" (toujours en partant de la fin vers le début)
    Oui en fait je cherche à faire une calculatrice polonaise, mais pas inversée, donc les opérandes se situent avant. Et je ne souhaite pas utiliser de piles non plus

  7. #7
    Expert éminent
    Avatar de Médinoc
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Septembre 2005
    Messages
    27 395
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 41
    Localisation : France

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Septembre 2005
    Messages : 27 395
    Par défaut
    Dans tous les cas, tu vas avoir besoin de quelque chose pour "remonter" dans ton arbre:
    • Soit dans l'arbre lui-même (pointeur vers le nœud parent)
    • Soit dans une pile explicite (genre une liste chaînée)
    • Soit dans la pile système.
    SVP, pas de questions techniques par MP. Surtout si je ne vous ai jamais parlé avant.

    "Aw, come on, who would be so stupid as to insert a cast to make an error go away without actually fixing the error?"
    Apparently everyone.
    -- Raymond Chen.
    Traduction obligatoire: "Oh, voyons, qui serait assez stupide pour mettre un cast pour faire disparaitre un message d'erreur sans vraiment corriger l'erreur?" - Apparemment, tout le monde. -- Raymond Chen.

Discussions similaires

  1. créer un arbre
    Par caro_caro dans le forum Wicket
    Réponses: 1
    Dernier message: 13/05/2009, 14h14
  2. Créer un arbre
    Par toussaga dans le forum Smalltalk
    Réponses: 1
    Dernier message: 01/06/2008, 10h31
  3. [LDAP] Créer un arbre LDAP
    Par khaoula_14_05 dans le forum Bibliothèques et frameworks
    Réponses: 1
    Dernier message: 13/03/2008, 18h31
  4. Créer un arbre avec cellules (treeview)
    Par Scritch852 dans le forum Macros et VBA Excel
    Réponses: 2
    Dernier message: 29/03/2007, 12h22

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