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

Algorithmes et structures de données Discussion :

Insertion d'un élément dans une liste simplement chainée triée (croissante)


Sujet :

Algorithmes et structures de données

  1. #1
    Futur Membre du Club
    Homme Profil pro
    Étudiant
    Inscrit en
    Novembre 2014
    Messages
    3
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Calvados (Basse Normandie)

    Informations professionnelles :
    Activité : Étudiant
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Novembre 2014
    Messages : 3
    Points : 5
    Points
    5
    Par défaut Insertion d'un élément dans une liste simplement chainée triée (croissante)
    Bonjour tout le monde,

    Voilà comme c'es indiqué dans le titre je voudrais un peu d'aide pour l'algorithme qui permet d'insérer un élément dans une liste chainée, pour l'ajouter au début ou à la fin c'est facile mais au milieu sachant que celle ci est triée de façon croissante, ça me pose quelques problèmes que je n'arrive à résoudre

    Merci pour votre aide !

  2. #2
    Membre régulier
    Homme Profil pro
    Inscrit en
    Mars 2010
    Messages
    60
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Mars 2010
    Messages : 60
    Points : 78
    Points
    78
    Par défaut
    Bonjour !

    En principe ta liste ressemble à ça :

    Code C : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    typedef struct{
       int value;
       TList *next;
    }TList;

    Donc pour insérer ailleurs qu'aux extrémités tu peux faire quelque chose comme :

    Code C : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    //tu crées ta nouvelle liste
    TList *newList = malloc...
    newList->value = v;
    //tu mets à jour les pointeurs et c'est fini
    newList->next = listeCourante->next;
    listeCourante->next = newList;

    Et le fait qu'elle soit triée n'ajoute pas de difficulté puisqu'il te suffit de comparer ta nouvelle valeur avec la valeur de listeCourante et de listeCourante->next pour trouver la bonne position.

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

Discussions similaires

  1. Réponses: 1
    Dernier message: 18/08/2010, 14h32
  2. [Free Pascal] Insertion d'éléments dans une liste chaînée
    Par Pacorabanix dans le forum Free Pascal
    Réponses: 4
    Dernier message: 20/04/2010, 00h42
  3. Réponses: 12
    Dernier message: 12/03/2007, 16h58
  4. Réponses: 3
    Dernier message: 25/10/2006, 19h08
  5. [debutant] insertion d'éléments dans une List
    Par gwenou60 dans le forum Composants
    Réponses: 1
    Dernier message: 05/12/2005, 09h59

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