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 :

Probleme--inserer et supprimer


Sujet :

C

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre averti
    Homme Profil pro
    Ingénieur systèmes et réseaux
    Inscrit en
    Mars 2007
    Messages
    42
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 38
    Localisation : Maroc

    Informations professionnelles :
    Activité : Ingénieur systèmes et réseaux
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Mars 2007
    Messages : 42
    Par défaut Probleme--inserer et supprimer
    probleme des arbres binaires

    je pense que mon programme est mal fonctionné


    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
    51
    52
    53
    54
    55
    56
    57
    58
    59
    60
    61
    62
    63
    64
    65
    66
    67
    68
    69
    70
    71
    72
    73
    74
    75
    76
    77
    78
    79
    80
    81
    82
    83
    84
    85
    86
    87
    88
    89
    90
    91
    92
    93
    94
    95
    96
    97
    98
    99
    100
    101
    102
    103
    104
    105
    106
    107
    108
    109
    110
    111
    112
    113
    114
    115
    #include <stdio.h>
    #include <conio.h>
    #include <malloc.h>
    typedef int type_val;
    typedef struct noeud
                      {
                      type_val T;
                      struct noeud *fg;
                      struct noeud *fd;
                      }racine;
    typedef racine *arbre;
    /*********************fonction ecrire**********************/
    void ecrire(type_val x)
    {
     printf("%d\n",x);
    }
    /********************fonction lire***************************/
    void lire(type_val *x)
    {
     scanf("%d",&x);
    }
    /*******************Fonction remplir****************/
     
    arbre remplir(type_val V,arbre l)
    {
    if(l==NULL)
      {
      l=(arbre)malloc(sizeof(racine));
      l->T=V;
      l->fg =NULL;
      l->fd =NULL;
     
      }
    else if(l->T<V)
         l->fd=remplir(V,l->fd);
    else l->fg=remplir(V,l->fg);
    return (l) ;
    }
    void afficher(arbre A,int niveau)
     { int i;
       if(A!=NULL)
            { for(i=0;i<niveau;i++)
                   printf("---");
                   ecrire(A->T);
                   afficher(A->fg,niveau+1);
                   afficher(A->fd,niveau+1);
     
            }
     }
     
    type_val suprimin(arbre *a)
    { arbre aux;
    type_val element;
     if (a!=NULL)
     {
      arbre aux;
                  if ((*a)->fg==NULL)
                    { element=(*a)->T;
     
                     aux=(*a);
                     (*a)=(*a)->fd;
                     free((*a)); }
                  else
                      element=suprimin(&(*a)->fg);
    }
    return (element);}
    /*********************menue*************************************/
    char menue()
    {
    char ch;
    //clrscr();
    printf("*****************Menu********************\n\n");
    printf("-Afficher........................ a\n");
    printf("-Supprimer.......................  s\n");
    printf("-Inserer.........................  i\n");
    printf("-Quitter.........................  q\n\n");
    printf("             votre choix       :");
    fflush(stdin);
    ch=getchar();
     
    return(ch);
    }
    /****************Fonction principale**************************/
     
     
    int main()
    {char c;
    arbre l=NULL;
    type_val x ;
    while ((c==menue())!='q')
     {
         switch(c)
         {
          case'i': printf("la valeur a inserer") ;
                     lire(&x);
                     l=remplir(x,l);break ;
          case's': printf("la valeur %d a ete suprimer\n",suprimin(&l));break;
          case'a': afficher(l,0);break;
          default    :printf("verifier le caractaire que vous avez tapez");  break;
         }
     
     
     }
     
    /*printf("entrer la valeur a inserer:  ");
    err=scanf("%d",&V);
    if(err<=0) break;
    l=remplir(V,l);
    }
    while(1);
     afficher(l,0);*/
     fflush(stdin);
     getchar();
    return(0) ;
    }

    vous pouvez m'aider svp ..??

  2. #2
    Expert confirmé
    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
    Par défaut
    Avant d'aller plus loin :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    void lire(type_val *x)
    {
     scanf("%d",x);
    }

  3. #3
    Expert éminent
    Avatar de Médinoc
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Septembre 2005
    Messages
    27 397
    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 397
    Par défaut
    Bonjour,
    1. On ne caste pas le retour de malloc() en C.
    2. <malloc.h> n'est pas un header standard, il faut inclure <stdlib.h> à la place.
    3. En fait, j'ai surtout des doutes sur ta fonction suprimin()...
    4. fflush(stdin) n'est pas standard non plus. Recherche les fonctions purge() et fpurge() sur le forum.

    Edit: Ah oui, le scanf()...
    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
    Homme Profil pro
    Ingénieur systèmes et réseaux
    Inscrit en
    Mars 2007
    Messages
    42
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 38
    Localisation : Maroc

    Informations professionnelles :
    Activité : Ingénieur systèmes et réseaux
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Mars 2007
    Messages : 42
    Par défaut
    vous pouvez executer le programme ..

    il est mal fonctionné

  5. #5
    Expert confirmé
    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
    Par défaut
    Avant d'aller encore plus loin :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    //main
    ...
    while ((c=menue())!='q')

Discussions similaires

  1. Réponses: 2
    Dernier message: 10/09/2012, 09h13
  2. Module PDF::API2 (probleme inserer image)
    Par LFC dans le forum Modules
    Réponses: 1
    Dernier message: 11/02/2012, 11h25
  3. Probleme impossible de supprimer des dossiers
    Par tomy7 dans le forum Macros et VBA Excel
    Réponses: 4
    Dernier message: 25/04/2008, 15h51
  4. probleme validation requete supprimer
    Par lorenzo74 dans le forum MS SQL Server
    Réponses: 8
    Dernier message: 30/06/2006, 14h09
  5. Probleme Inserer une image
    Par Federico_28 dans le forum IHM
    Réponses: 2
    Dernier message: 24/04/2006, 12h05

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