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 :

Fusion d'arbre en C


Sujet :

C

  1. #1
    Futur Membre du Club
    Femme Profil pro
    Technicien Help Desk
    Inscrit en
    Avril 2009
    Messages
    9
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : Suisse

    Informations professionnelles :
    Activité : Technicien Help Desk
    Secteur : Santé

    Informations forums :
    Inscription : Avril 2009
    Messages : 9
    Points : 9
    Points
    9
    Par défaut Fusion d'arbre en C
    Bonjour à toutes et à tous,

    Je fais appel à vous et à vos connaissance pour fusionner deux arbres en un seul.

    Je ne sais pas trop comment m'y prendre, avez vous une idée ?

    Merci encore poour votre aide

    Harmonia

  2. #2
    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
    Bonjour et bienvenue sur les forums de DVP.

    Il faut préciser ce que tu veux obtenir et le critère régissant la fusion.

    Sont-ce deux arbres binaires de recherche ? A fusionner pour en obtenir un troisième ou faire la fusion sur l'un d'entre eux ?
    Publication : Concepts en C

    Mon avatar : Glenn Gould

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

  3. #3
    Futur Membre du Club
    Femme Profil pro
    Technicien Help Desk
    Inscrit en
    Avril 2009
    Messages
    9
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : Suisse

    Informations professionnelles :
    Activité : Technicien Help Desk
    Secteur : Santé

    Informations forums :
    Inscription : Avril 2009
    Messages : 9
    Points : 9
    Points
    9
    Par défaut Fusion d'arbre
    Merci pour ta réponse rapide...

    Voilà j'ai un arbre contenant des valeurs positives et un autre arbre contenant des valeurs négatives.

    J'aurai aimé créer un troisième arbre regroupant les valeurs des deux arbres précédement créé

  4. #4
    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
    Il nous faut plus d'information sur la structure de tes arbres. Comment sont-il organisés ?

  5. #5
    Futur Membre du Club
    Femme Profil pro
    Technicien Help Desk
    Inscrit en
    Avril 2009
    Messages
    9
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : Suisse

    Informations professionnelles :
    Activité : Technicien Help Desk
    Secteur : Santé

    Informations forums :
    Inscription : Avril 2009
    Messages : 9
    Points : 9
    Points
    9
    Par défaut Code
    Voici la 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
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    typedef int typedonnee; // type des données
     
    /* Définition d'un noeud */
    typedef struct n {
      typedonnee val;
      struct n *gauche;
      struct n *droit;
    } typeNoeud;
     
    /* Saisie une valeur entiere au clavier */
    int saisieEntier ();
     
    /* Fusion de deux arbres en un seul */
    typeNoeud *fusionArbres (typeNoeud *arbre1, typeNoeud *arbre2, typedonnee val);
     
    void main (){
    	typedonnee val;
    	typeNoeud *racinePos;
    	typeNoeud *racineNeg;
    	typeNoeud *racineFus;
     
    	int i;
     
    	printf("Saisie des valeurs :\n");
    	printf("------------------\n");
     
    	/* Initialisation de l'arbre binaire */
    	initArbre(&racinePos);
    	initArbre(&racineNeg);
     
    	/* Saisie de valeurs */
    	printf ("Valeur a inserer : ");
    	val = saisieEntier ();
     
    	while (val != 0){
    		if (val >= 0){
    			/* Insere la valeur dans le noeud positif */
    			insereNoeud(&racinePos, val);
    		}else{
    			/* Insere la valeur dans le noeud negatif */
    			insereNoeud(&racineNeg, val);
    		}
     
    		/* Saisie de valeurs */
    		printf ("Valeur a inserer : ");
    		val = saisieEntier ();
    	}
     
    	system("pause");
    }

  6. #6
    Expert éminent sénior
    Avatar de Sve@r
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Février 2006
    Messages
    12 689
    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 689
    Points : 30 983
    Points
    30 983
    Billets dans le blog
    1
    Par défaut
    Citation Envoyé par harmonia1981 Voir le message
    Voici la 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
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    typedef int typedonnee; // type des données
     
    /* Définition d'un noeud */
    typedef struct n {
      typedonnee val;
      struct n *gauche;
      struct n *droit;
    } typeNoeud;
     
    /* Saisie une valeur entiere au clavier */
    int saisieEntier ();
     
    /* Fusion de deux arbres en un seul */
    typeNoeud *fusionArbres (typeNoeud *arbre1, typeNoeud *arbre2, typedonnee val);
     
    void main (){
    	typedonnee val;
    	typeNoeud *racinePos;
    	typeNoeud *racineNeg;
    	typeNoeud *racineFus;
     
    	int i;
     
    	printf("Saisie des valeurs :\n");
    	printf("------------------\n");
     
    	/* Initialisation de l'arbre binaire */
    	initArbre(&racinePos);
    	initArbre(&racineNeg);
     
    	/* Saisie de valeurs */
    	printf ("Valeur a inserer : ");
    	val = saisieEntier ();
     
    	while (val != 0){
    		if (val >= 0){
    			/* Insere la valeur dans le noeud positif */
    			insereNoeud(&racinePos, val);
    		}else{
    			/* Insere la valeur dans le noeud negatif */
    			insereNoeud(&racineNeg, val);
    		}
     
    		/* Saisie de valeurs */
    		printf ("Valeur a inserer : ");
    		val = saisieEntier ();
    	}
     
    	system("pause");
    }
    Tu as bien compris que l'élément essentiel était la modularité. Tu as donc écrit une fonction "insereNoeud" qui se charge d'insérer le nombre dans l'arbre au bon endroit. Ben te suffit de parcourir les arbres positifs et négatifs en récupérant les nombres stockés et d'appeler la fonction "insereNoeud" pour insérer le nombre récupéré dans l'arbre fusion.

    Toutefois, quand on crée un arbre c'est qu'on possède un certain besoin concernant l'ordonnancement. Par exemple on place les nombres plus petits que le nombre central du coté gauche, et les nombres plus grand du coté droit. Ou bien ceux qui sont divisibles et ceux qui ne le sont pas. Ou toute autre raison. Le critère importe peu mais il faut qu'il y en ait un sinon on n'a aucun avantage à utiliser un arbre par rapport à une liste ou même un simple tableau qu'on fait grossir. Or ici on n'a aucune idée de la façon dont tu ranges tes nombres. Prenons un exemple (en restant dans les positifs) avec les nombres 16, 10 et 20. Le nombre 16 ira donc en tête de l'arbre (puisqu'il est vide). Mais arrive le nombre 10. Vas-tu le placer à droite ou à gauche du 16 et pourquoi ?
    Admettons que le 10 ait été placé à gauche (avec ce critère pour le moment inconnu). Arrive maintenant le 20. Va-t-il aller à droite ou à gauche du 16 ? Et s'il va à gauche et arrive sur le 10, va-t-il aller à droite ou à gauche du 10 ?
    Répond à ces questions et tu sauras de toi-même comment fusionner tes 2 arbres dans le 3°.

    Autres défaut: main() est de type int, pas void. Et généralement on nomme ses structures "s_qqchose" et ses types "t_qqchose" ce qui est plus parlant que ce "n" de "struct n". Et tu peux éviter cette répétition de saisie en faisant preuve d'un peu d'astuce et/ou en utilisant le do... while.
    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]

Discussions similaires

  1. Tri par fusion d'un tableau
    Par Mailgifson dans le forum C
    Réponses: 5
    Dernier message: 12/12/2002, 14h53
  2. arbres BB
    Par cedrick essale dans le forum Algorithmes et structures de données
    Réponses: 4
    Dernier message: 03/12/2002, 15h39
  3. Qu'est ce qu'un arbre
    Par sandrine dans le forum C
    Réponses: 8
    Dernier message: 23/10/2002, 13h12
  4. créer une arborescence windows sous forme d'arbre java
    Par chupachoc dans le forum Composants
    Réponses: 3
    Dernier message: 01/10/2002, 16h48
  5. arbre de parcour d'arborescence windows
    Par chupachoc dans le forum Composants
    Réponses: 7
    Dernier message: 09/09/2002, 08h09

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