Vous ne trouvez pas de réponse à votre problème ? Alors posez la question dans le forum. Souvenez-vous qu'il n'y a jamais de question bête, mais rester dans l'ignorance parce que l'on n'ose pas poser une question, ça c'est une erreur !

Sujet : Trie liste chainée simple [ Archives / Au secours ] (angelfire0808)

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é 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 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& tester valeur lors d'une lecture [ par MrKro ] Voila je doit faire un programme qui lit des infos dans un fichier et les traite par la suite, en fait c'est pour coder des graphes. Le morceau de cod Pointeurs de pointeurs [ par miximog ] Bonjour a tous enfin bonsoir ;) Enfaîte j'ai lu 2 tuto sur les pointeurs donc je commence a bien comprendre la notion de pointeurs, mais il y a une n tri clist [ par ObiWanKennedy ] Bonjours, Alors voilà mon problème, je voudrais trier ma Clist mais j'ai quelques problèmes. J'explique vite fait le principe.Je pars d'une liste vide


Nos sponsors

Sondage...

CalendriCode

Juillet 2009
LMMJVSD
  12345
6789101112
13141516171819
20212223242526
2728293031  

Consulter la suite du CalendriCode

Téléchargements

Logiciels à télécharger sur le même thème :

Comparez les prix Nouvelle version

Photothèque Nouveau !



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
Temps d'éxécution de la page : 0,686 sec

Google Coop CodeS-SourceS Google Coop CodeS-SourceS


Certaines images présentes sur le site (notament certains avatars) sont issues des collections IconShock, donc si vous souhaitez utiliser ces icons vous devez les acheter, ne les copiez pas et ne utilisez pas dans vos sites et applications sans les avoir commandé.