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 :

Savoir si un arbre est vide


Sujet :

C

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre confirmé
    Profil pro
    Étudiant
    Inscrit en
    Juillet 2007
    Messages
    113
    Détails du profil
    Informations personnelles :
    Âge : 38
    Localisation : France

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Juillet 2007
    Messages : 113
    Par défaut Savoir si un arbre est vide
    Bonjour et bonnes fêtes à tous,

    Je me permet de faire appel à vous pendant cette période car je n'arrive pas à savoir si un arbre est vide. Voici mon code :

    Declaration des structures
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    //Definition de la structure d'un noeud
    typedef struct _Noeud {
    	int valeur;
    	struct _Noeud * gauche;
    	struct _Noeud * droit;
    } Noeud;
     
    //A retenir : le type ABR est un type "pointeur sur 'Noeud'".
    typedef Noeud * ABR;
    Declaration de la fonction
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    int est_vide(ABR a){
    	//On renvoi directement le résultat de la comparaison
    	return(a == NULL);
    }
    Utilisation
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    //Declaration des variables
    printf("//Declaration des variables : ABR\r\n");
    ABR arbre_test;
    puts("");
     
    //Vérification du vide de l'arbre
    printf("//Verification du vide de l'arbre\r\n");
    printf("%i\r\n",est_vide(arbre_test));
    puts("");
    Voila, avec tout ceci, j'obtiens 0 alors que l'arbre est vide... Par conséquent, et après avoir lu de document sur les arbres de Romuald, j'aimerais que quelqu'un puisse me dire ce que j'ai loupé ou m'explique une autre façon de faire. D'avance merci.

    Altrensa

  2. #2
    Expert confirmé

    Inscrit en
    Août 2006
    Messages
    3 967
    Détails du profil
    Informations forums :
    Inscription : Août 2006
    Messages : 3 967
    Par défaut
    Dio,

    Quand on déclare un pointeur, il faut l'initialiser à NULL pour éviter les surprises.

    Comme la valeur qu'il prend sans cette précaution a peu de chance de correspondre à NULL...

  3. #3
    Membre confirmé
    Profil pro
    Étudiant
    Inscrit en
    Juillet 2007
    Messages
    113
    Détails du profil
    Informations personnelles :
    Âge : 38
    Localisation : France

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Juillet 2007
    Messages : 113
    Par défaut
    Merci beaucoup !

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. [xml][asp_vbscript] savoir si un SelectSingleNode est vide
    Par nicko5959 dans le forum XML/XSL et SOAP
    Réponses: 4
    Dernier message: 16/01/2006, 09h09
  2. [formulaire] savoir si un form est vide
    Par francois78 dans le forum IHM
    Réponses: 3
    Dernier message: 07/11/2005, 15h23
  3. Savoir si un Timage est vide
    Par jmjmjm dans le forum Composants VCL
    Réponses: 6
    Dernier message: 17/10/2005, 22h41
  4. comment savoir si un recordset est vide ?
    Par alkmehd dans le forum Access
    Réponses: 6
    Dernier message: 15/09/2005, 14h56
  5. [Access] Comment savoir qu'un champs est vide ?
    Par Oberown dans le forum ASP
    Réponses: 9
    Dernier message: 25/10/2004, 10h47

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