begin process at 2012 02 13 00:21:23
  Trouver un code source :
 
dans
 
Accueil > Forum > 

Archive C/C++

 > 

Archives

 > 

Au secours

 > 

Trie liste chainée simple


Derniers messages déposésPoser une question dans le forum ou lancer une discussion

Trie liste chainée simple

lundi 10 avril 2006 à 16:21:54 | Trie liste chainée simple

angelfire0808


Bonjour, voila j'essaye d'apprendre à trier une liste chainée mais j'ai quelques soucis



#include<stdio.h>
#include<stdlib.h>
#include<string.h>
#include<conio.h>





struct liste

        {

        int valeur;

        struct liste *suivant; //pointe vers l'élément suivant

        };
 
typedef struct liste liste_s ,*pt_cellule,*liste;






void ajout_tete(pt_cellule *tete,int t)
{
liste_s *nouveau; //nouvelle entrée dans la liste chainée
nouveau=(liste_s *)malloc(sizeof (liste_s)); // on assigne une case memoire pour la nouvelle valeur

nouveau->valeur=t; //la valeur de la nouvelle case prend le scanf (variable t)
nouveau->suivant=*tete; // le pointeur de nouveau pointe sur la tete actuelle pour se lier à un autre maillon
(*tete)=nouveau; //on donne à tete la 1er valeur de la chaine (l'adresse)


}





void affichage(pt_cellule *tete)
{
liste l=*tete;

    while(l != NULL)
    {     
        printf("valeur : %d\n",l-> valeur);
        l=l->suivant;
    }
}





// Voici l'endroit qui me pose probleme
void tri(pt_cellule *tete)
{
liste actuel = *tete;
liste precedent = actuel->suivant;
liste tmp = NULL;


printf("actuel : %d\n",actuel-> valeur);
printf("precedent : %d\n",precedent-> valeur);
       

while(precedent != NULL)
{   


if (actuel < precedent)

              {
                             
                                   
                       tmp = precedent;
                       precedent = actuel; 
                       actuel  = tmp ;
     
                             
             }; 
            
            
actuel=actuel->suivant;
        
}

affichage(tete);

    
}




int main()
{
int t=-1;

pt_cellule tete=NULL; //pointeur de tete initialisé à 0


while (t!=0)

    {

        printf("saisie :\n");
      
        scanf("%d",&t);
        if (t==0) break;
        ajout_tete(&tete,t);

    }

affichage(&tete);
tri(&tete);
return 0;
}











mercredi 12 avril 2006 à 21:59:11 | Re : Trie liste chainée simple

sebome

"if (actuel<precedent)"  la tu compar deux pointeur sur ta liste il é pas la le probleme par hasard??
Ca serai pas les valeur que tu voudrais comparer?

Sébome



Cette discussion est classée dans : tete, valeur, liste, precedent, actuel


Répondre à ce message

Sujets en rapport avec ce message

constrution d'un arbre [ par eglentine ] bonjour, j'esseye de construire un arbre pour la compression jpeg d'une image, et j'utilise le methode de huffman.g utilisé une liste qui contiendra l travail sur les files (assez urgent :) ) [ par tagada_du_loft ] voila je doit inserer un elt en tete de file "1ere fonction"et en oter le dernier elt de la file "2eme"les structure de bases sont:******************* Listes chainées [ par angelfire0808 ] Bonjour voila voici mon, code j'ai une ereeur de compilation mais je ne comprend pas ;-(l'erreur c'est ici :   " nouveau->suivant=(*tete); ".De plus j Liste chainée passée en paramètre [ par morayma ] J'ai écrit un petit programme qui appelle une procédure qui ajoute des éléments à une liste chainée simple. Mon problème c'est que la liste n'est pas trier une liste simplement chaine [ par mdh12 ] je veux faire le trie d'une liste chaine mon code ne me donne pas le resulta juste pouvez le couriger #include #include #include typedef struct noe Récupérer valeur combobox (liste déroulante) [ par lolorenzeb ] Salut à tous,Voila je réalise une appli graphique avec les API et j'utilise un combobox.Mon problème est que j'aimerai récupérer la valeur sélectionne Recherche de la plus grand valeur dans une liste chainée [ par doudou0088 ] Bonjour, J'ai une liste chainé contenant une valeur entière pour chaque élément (environ 96 éléments). J'aimerai affiché l'entier le plus grand de cet Problem de 'left operand must be a lvalue" [ par Orezza ] Voila je vous mets le code qui est un code trouver sur ce site mais que j'ai modifié. je ne comprends pas les erreurs de compilations pourriez-vous ra liste chainée double générique [ par issoux ] Bonsoir ,  j'ai un probleme dans mon code :  Code: #include <stdlib.h& insertion par tri sur une liste chainée [ par Akhelios ] Salut tous, Je voulais réaliser une fonction d'ajout par tri dans une liste chaînée, sauf que ça marche pas et je me demande pourquoi, bon voilà le co


Nos sponsors


Sondage...

Comparez les prix

CalendriCode

Février 2012
LMMJVSD
  12345
6789101112
13141516171819
20212223242526
272829    

Consulter la suite du CalendriCode

 
Développement réalisé par Nicolas SOREL (Nix) avec l'aide de : Cyril DURAND et Emmanuel (EBArtSoft), Merci à Vincent pour ses précieux conseils.
CodeS-SourceS.com© Toute reproduction même partielle est interdite sauf accord écrit du Webmaster
CodeS-SourceS.com© est une marque déposée tous droits réservés

Google Coop CodeS-SourceS Google Coop CodeS-SourceS
Temps d'éxécution de la page : 2,886 sec (4)

Nous contacter | Annoncer sur CodeS-SourceS | Mentions légales