Posez votre question Signaler

Arbre en c

oscar - Dernière réponse le 25 nov. 2010 à 12:55
bonjour

j'ai des problèmes pour codifier un arbre binaire en c (pacours infixé post fixé prefixé; aidez moi svp
merci.
Lire la suite 

Arbre en c »

10 réponses
Réponse
+3
moins plus
Salut,

voici un exemple (à toi d'adapter)
#include<stdio.h>
#include<stdlib.h>

typedef struct N_
{
  int nb;
  struct N_*gauche;
  struct N_*droite;
} Noeud;

void CreerArbre (Noeud ** racine, int n);
void Traiter (Noeud * racine);
void AfficherPrefixe (Noeud * racine);
void AfficherPostfixe (Noeud * racine);
void AfficherInfixe (Noeud * racine);

Noeud *alloc ();

int main ()
{
  Noeud *racine;

  racine = NULL;
  int n;

  printf ("Numéro [100 pour terminer] ? ");
  scanf ("%d", &n);
  while (n != 100) {
    CreerArbre (&racine, n);
    printf ("Numéro [100 pour terminer] ? ");
    scanf ("%d", &n);
  }
  AfficherPrefixe (racine);
  puts ("");
  AfficherInfixe (racine);
  puts ("");
  AfficherPostfixe (racine);
  puts ("");
  return 0;
}

void CreerArbre (Noeud ** racine, int n)
{
  Noeud *nouveau;

  nouveau = alloc ();

  if (*racine == NULL) {
    nouveau->nb = n;
    nouveau->gauche = NULL;
    nouveau->droite = NULL;
    *racine = nouveau;
  }
  else if (n < (*racine)->nb)
    CreerArbre (&(*racine)->gauche, n);
  else if (n > (*racine)->nb)
    CreerArbre (&(*racine)->droite, n);
}


Noeud *alloc ()
{
  Noeud *noeud;

  noeud = (Noeud *) malloc (sizeof (Noeud));
  return noeud;
}

void Traiter (Noeud * racine)
{
  printf ("%d (%p) ; ", racine->nb, racine);
}

void AfficherPrefixe (Noeud * racine)
{
  if (racine != NULL) {
    Traiter (racine);
    AfficherPrefixe (racine->gauche);
    AfficherPrefixe (racine->droite);
  }
}
void AfficherPostfixe (Noeud * racine)
{
  if (racine != NULL) {
    AfficherPostfixe (racine->gauche);
    AfficherPostfixe (racine->droite);
    Traiter (racine);
  }
}


void AfficherInfixe (Noeud * racine)
{
  if (racine != NULL) {
    AfficherInfixe (racine->gauche);
    Traiter (racine);
    AfficherInfixe (racine->droite);
  }
}
tissafi - 4 avril 2010 à 18:53
mercciiiii mon ami pour tttt
Ajouter un commentaire
Réponse
+3
moins plus
Merci lami20j,
C'est génial.

Cpdant, j'ai écris un truc qui me coince à tout moment avec des erreur.

Donc je veux un qui marche sans error, afin de bien comprendre les contours de C.

Je rappelle mon 1er prob:


Un programme C qui me permet de retrouver la représentation fonctionnelle d'un arbre abstrait:
1- à partir de sa représentation préfixée d'une part,
2 - et de sa représentation postfixée d'autre part,
3 - en fin de sa représentation infixée.

Bonne soirée
Ajouter un commentaire
Réponse
+0
moins plus
je peux te filer des fonction pour les parcours d'arbre et compagnie mais faut attendre demain...
pathus - 25 nov. 2010 à 12:55
bonjour,
est ce que vous pouvez me filer des fonctions de parcours dans un arbre et compagnie??
Ajouter un commentaire
Réponse
+0
moins plus
BON TU VEUX DES FONCTIONS EN RECURSIF?
gdavis - 7 juin 2008 à 19:53
Bsoir COC.C

Tu sais, je suis un débutant en C.
Ainsi, il me faut quelque chose qui marche bien pour me permettre de comprendre les contours de cet environnement également.

Des fonctions récursives ne me gêneront pas.

L'optimisation viendra après.

Bne soiréé
Ajouter un commentaire
Réponse
+0
moins plus
Bonsoir

Qu'est ce qui fait la différence entre un code écrit en c sous windows et le même code en c sous linux?
Titi - 10 nov. 2008 à 16:07
Y'en a pas

Bon courage
Ajouter un commentaire
Réponse
+0
moins plus
bonjour , j'utilise les outil lex et yacc pour concevoir une grammaire connue , j'ai besoin d'une méthode pour le parcour d'un arbre n-aire au niveau de yacc ( méthode écrite en C )
merci
Ajouter un commentaire
Ce document intitulé « arbre en c » issu de CommentCaMarche (www.commentcamarche.net) est mis à disposition sous les termes de la licence Creative Commons. Vous pouvez copier, modifier des copies de cette page, dans les conditions fixées par la licence, tant que cette note apparaît clairement.
Dossier à la une
Windows 8 - À quoi s'attendre ?