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 sur une liste chainée


Sujet :

C++

  1. #1
    Membre à l'essai
    Profil pro
    Inscrit en
    Mars 2008
    Messages
    32
    Détails du profil
    Informations personnelles :
    Localisation : Canada

    Informations forums :
    Inscription : Mars 2008
    Messages : 32
    Points : 20
    Points
    20
    Par défaut Tri sur une liste chainée
    Bonsoir à tous.

    J'ai un petit pépin dans pour finaliser un de mes projets. Vous pourriez peut-être me donner un coup de pouce.

    Je lis des donnés à partir d'un fichier texte puis je crée une liste chainée que j'utilise plus tard dans mon code. Dans chaque noeud, on retrouve la description d'un produit.

    Je voudrais donc trier ma liste chainée ( à la création ou post-création) par ordre alphabetique de produit. Je ne dois pas utliser la libraire STL donc pas de sort(), tous doit etre fais manuellement. Voici mon noeud:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
     
    struct Produit {
    	int numProduit;
    	char description [29];
    	float prix;
    	int quantite;
    	int qteVendue;
    	Produit* suiv;
    };
    Et voici la fonction qui me permet d'inserer un nouveau noeud a la liste déja présente.
    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
     
     
    //Insertion produits a la fin 
    void InsertionProduit(DescListe &DL, Produit* n){	
    	Produit* pt = DL.teteProd;
     
    	if(DL.teteProd == NULL){//si Ma liste est vide
    		DL.teteProd = n;
     
    	}else{	//On rajoute a la fin
    		while(pt->suiv != NULL)
    			pt = pt->suiv;
    		pt->suiv = n;		
    	}
    }
    Je dois donc comparer le champ "description" et inserer à la bonne position.
    Trier à la l'insertion me parait l'option la plus propre. Donc si je ne fais pas fausse route, il faudra gérer 4 cas:
    1. Liste vide
    2. Inserer à la place de la tete
    3. Inserer en plein mileu
    4. Inserer à la fin


    Merci pour votre aide.

  2. #2
    Membre averti
    Homme Profil pro
    Analyse système
    Inscrit en
    Novembre 2008
    Messages
    227
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Analyse système
    Secteur : High Tech - Électronique et micro-électronique

    Informations forums :
    Inscription : Novembre 2008
    Messages : 227
    Points : 311
    Points
    311
    Par défaut
    Il te faut pour celà surcharger les opérateurs >, < et == dans ta classe produit. Celà te permettra d'effectuer ensuite facilement le tri.

  3. #3
    Rédacteur
    Avatar de 3DArchi
    Profil pro
    Inscrit en
    Juin 2008
    Messages
    7 634
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2008
    Messages : 7 634
    Points : 13 017
    Points
    13 017
    Par défaut
    Salut,
    Citation Envoyé par Leclandestin Voir le message
    1. Liste vide
    2. Inserer à la place de la tete
    3. Inserer en plein mileu
    4. Inserer à la fin
    Ce sera déjà un bon début.

    Mais sinon, c'est quoi la question ? Qu'on te le fasse à ta place ?

  4. #4
    Membre régulier
    Profil pro
    INGENIEUR DE RECHERCHE
    Inscrit en
    Février 2003
    Messages
    74
    Détails du profil
    Informations personnelles :
    Âge : 57
    Localisation : France, Charente Maritime (Poitou Charente)

    Informations professionnelles :
    Activité : INGENIEUR DE RECHERCHE

    Informations forums :
    Inscription : Février 2003
    Messages : 74
    Points : 87
    Points
    87
    Par défaut
    Même question c'est quoi la question?
    Sinon on peut, suivant la taille de la liste :

    Ajouter
    Trier

    Mais il faut bien sur réaliser une fonction de tri.
    Spiale

  5. #5
    Membre à l'essai
    Profil pro
    Inscrit en
    Mars 2008
    Messages
    32
    Détails du profil
    Informations personnelles :
    Localisation : Canada

    Informations forums :
    Inscription : Mars 2008
    Messages : 32
    Points : 20
    Points
    20
    Par défaut
    Bonjour,

    Me guider vers la bonne démarche à suivre serait apprecié. J'imagine qu'il y a plusieurs facon d'effectuer ce tri. Je ne vous demande pas de le faire à ma place(n'est ce pas 3D archi). Mais plutot de me guider vers la meilleure option à prendre. J'ai réussi à effectuer le tri à l'insertion: voici le code.

    Quelqu'un voit une meilleure solution?
    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
    void InsertionProduit(DescListe &DL, Produit* n){
    	Produit *temp,*pt2,*pt1;
    	int i=0;//ns indique combien de fois on a comparer et le resultat >0
    	bool b=false;//ns indique si on a inserer l element
    	if(DL.teteProd== NULL){//si Ma liste est vide
    		DL.teteProd  = n;
    	}else{
    	    pt2 = DL.teteProd;
    	    pt1=DL.teteProd;
    		while(pt2 != NULL && !b){
                if (strcmp(n->description,pt2->description)>0){
                    pt1=pt2;
                    pt2=pt2->suiv;
                    i++;
                }
                else{
                    temp=pt2;
                    n->suiv=temp;
                    if(i>0) pt1->suiv=n;
                    else n=DL.teteProd;
                    b=true;
                }
    		}
    		if (!b) pt1->suiv=n; //cas ou l element a inserer doit etre a la fin
    	}
        DL.nbProd++;
    }

  6. #6
    screetch
    Invité(e)
    Par défaut
    c'est une liste simplement chainée. Pas forcément que ca va être galère, mais déjà un tri par bulle pourrait déjà marcher. Pour des choses plus efficaces, il se pourrait que tu doives utiliser une liste doublement chaînée a la place.
    http://en.wikipedia.org/wiki/Sorting...ing_algorithms

Discussions similaires

  1. Tri par insertion sur une liste chainé simple.
    Par loula427 dans le forum Débuter
    Réponses: 6
    Dernier message: 21/03/2011, 14h54
  2. Tri sur une list(of) avec classe perso
    Par Faladin dans le forum VB.NET
    Réponses: 9
    Dernier message: 04/08/2008, 20h13
  3. Tri sur une liste d'objet
    Par Poussy-Puce dans le forum C#
    Réponses: 4
    Dernier message: 12/05/2008, 17h35
  4. tri sur une list
    Par lastrecrue dans le forum C++
    Réponses: 2
    Dernier message: 18/04/2007, 08h44

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