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 :

tri de pile en C !


Sujet :

C

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Futur Membre du Club
    Étudiant
    Inscrit en
    Janvier 2009
    Messages
    3
    Détails du profil
    Informations personnelles :
    Âge : 37

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Janvier 2009
    Messages : 3
    Par défaut tri de pile en C !
    ben salut tout le monde jvoudré faire le tri d'une pile en structure chainé mais je cale ché po tro cmn faire

    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
     
    #include <stdio.h>
    #include <stdlib.h>
     
    typedef struct elem{
        int val; /* La donnee que notre pile stockera */
        struct elem *pred; /* Pointeur vers l'élément précédent de la pile */
    } *pile;
     
     
    pile empile(pile p, int val){
        pile q;
        q=(pile)malloc(sizeof(struct elem));
        if (q != NULL){
            q->val = val;
            q->pred = p;
            p = q;
        }
        return p;
    }
     
    int depile(pile p){
        int ret = -1;
        if (p != NULL){
            pile temp = p->pred;
            ret = p->val;
            free(p), p = NULL;
            p = temp;
        }
        return ret;
    }
     
    void pile_supp(pile p){
        while (p != NULL){
            depile(p);
        }
    }
     
    void affiche (pile p){
        if (p!=NULL){
            while (p!=NULL){
                printf("%d\n",p->val);
                p=p->pred;
            }
        }
        else
        printf("la pile est vide !\n");
     
    }
     
    pile tri_pile(pile p){
        pile travail=NULL;
        pile tri=NULL;
        int x,v;
        while (p!= NULL){
            x=depile(p);
            tri=empile(tri, x);
            if (p->val <= tri->val){
                x=depile(p);
                tri=empile(tri, x);
            }
            else{
                while((tri!= NULL)&&(p->val > tri->val)){
                    v= depile(tri);
                    travail=empile(travail, v);
     
                    x=depile(p);
                    tri=empile(tri, x);
                }
            }
        }
        return tri;
    }
     
     
     
    int main(){
        pile p=NULL;
        int aret, v, nb;
     
        printf("donnez la valeur de l'element d'aret \n");
        scanf("%d",&aret);
        nb=0;
        do {
        printf(" tapez l element de la pile != %d \n",aret);
            scanf("%d",&v);
            p=empile(p,v);
            printf("\n la pile 1 est \n");
            affiche(p);
            nb++;
        } while (v!= aret);
     
    p=tri_pile(p);
    affiche(p);
    return 0;
    }


    ------------------------------------------------------------
    [EDIT]
    Traduction (enfin je suppose) :
    ben salut tout le monde jvoudré faire le tri d'une pile en structure chainé mais je cale ché po tro cmn faire
    Salut tout le monde. Je voudrais faire le tri d'une pile utilisant une structure de liste chaînée, mais je cale. Je ne sais pas trop comment faire
    [/EDIT]

  2. #2
    Expert éminent
    Avatar de Emmanuel Delahaye
    Profil pro
    Retraité
    Inscrit en
    Décembre 2003
    Messages
    14 512
    Détails du profil
    Informations personnelles :
    Âge : 68
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Retraité

    Informations forums :
    Inscription : Décembre 2003
    Messages : 14 512
    Par défaut
    Citation Envoyé par Tshik3StyLe Voir le message
    ben salut tout le monde jvoudré faire le tri d'une pile en structure chainé mais je cale ché po tro cmn faire
    Commence par écrire dans une langue compréhensible...

  3. #3
    Membre éprouvé
    Profil pro
    Étudiant
    Inscrit en
    Janvier 2009
    Messages
    142
    Détails du profil
    Informations personnelles :
    Âge : 37
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Janvier 2009
    Messages : 142
    Par défaut
    Salut,

    es-tu sur d'avoir choisi la bonne Structure de donnée pour effectuer un tri ?

  4. #4
    Futur Membre du Club
    Étudiant
    Inscrit en
    Janvier 2009
    Messages
    3
    Détails du profil
    Informations personnelles :
    Âge : 37

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Janvier 2009
    Messages : 3
    Par défaut
    ben Diogene merci de me corrigé

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

Discussions similaires

  1. Tri d'une pile avec liste simplement chainée
    Par thecabbages dans le forum C
    Réponses: 3
    Dernier message: 17/12/2009, 21h08
  2. Tri multi-threadé
    Par Tifauv' dans le forum C
    Réponses: 8
    Dernier message: 28/06/2007, 09h00
  3. tri de liste chainée
    Par RezzA dans le forum C
    Réponses: 7
    Dernier message: 26/01/2003, 20h25
  4. [TASM] Déclarer le segment de pile
    Par cipher dans le forum x86 16-bits
    Réponses: 2
    Dernier message: 01/10/2002, 03h58
  5. [] Tri d'un tableau par ordre alphabétique
    Par cafeine dans le forum VB 6 et antérieur
    Réponses: 3
    Dernier message: 17/09/2002, 08h43

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