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 :

Inverser les éléments d'une liste


Sujet :

C

  1. #1
    Membre à l'essai
    Profil pro
    Étudiant
    Inscrit en
    Juillet 2009
    Messages
    15
    Détails du profil
    Informations personnelles :
    Âge : 34
    Localisation : Sénégal

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Juillet 2009
    Messages : 15
    Points : 14
    Points
    14
    Par défaut Inverser les éléments d'une liste
    J'ai écrit une fonction qui inverse les éléments de la liste. Le prototype de la fonction est :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    int rev_list(t_list **begin)
    Je suis passée par la méthode des nouveaux éléments mais j'aimerai savoir comment appliquer rien qu'un jeu de pointeurs.

    Merci d'avance.

  2. #2
    Membre expert Avatar de jabbounet
    Homme Profil pro
    Consultant informatique
    Inscrit en
    Juin 2009
    Messages
    1 909
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 48

    Informations professionnelles :
    Activité : Consultant informatique

    Informations forums :
    Inscription : Juin 2009
    Messages : 1 909
    Points : 3 284
    Points
    3 284
    Par défaut
    Il ne serait pas plus simple d'utiliser une liste circulaire doublement chainée?


    en fonction du sens de parcours tu as ta liste dans un sens ou dans l'autre.
    bazar: http://www.improetcompagnie.com/publ...ctacles-6.html

    BÉPO la disposition de clavier francophone, ergonomique et libre: http://bepo.fr/wiki/Accueil

    Emacs Wiki: http://www.emacswiki.org/

    En attente de ce que produira: http://www.pushmid.com

  3. #3
    Membre à l'essai
    Profil pro
    Étudiant
    Inscrit en
    Juillet 2009
    Messages
    15
    Détails du profil
    Informations personnelles :
    Âge : 34
    Localisation : Sénégal

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Juillet 2009
    Messages : 15
    Points : 14
    Points
    14
    Par défaut
    si mais comme je l ai dit je voudrais plutot une methode par pointeurs

  4. #4
    Membre expert Avatar de jabbounet
    Homme Profil pro
    Consultant informatique
    Inscrit en
    Juin 2009
    Messages
    1 909
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 48

    Informations professionnelles :
    Activité : Consultant informatique

    Informations forums :
    Inscription : Juin 2009
    Messages : 1 909
    Points : 3 284
    Points
    3 284
    Par défaut
    euh ???

    si je me souviens bien de mes cours de C/C++, une liste chainée et encore plus si elle l'est doublement référence les éléments (suivant et précédent) grâce a des pointeurs....

    ou alors j'ai raté quelque chose....

    Si tu veux vraiment passer par une fonction sans liste circulaire doublement chainée (cela sera peu être plus couteux)
    l'algo est le suivant:
    Tu crée une nouvelle liste (vide).
    En boucle (ça va te couter très cher si la liste est longue): tu va chercher le dernier élément de ta liste (ça va couter cher si la liste est longue) tu le retire et tu l'insère dans la nouvelle.


    Maintenant si ta liste est circulaire et doublement chainée et que tu veux l'inverse tu swap chacun des pointeur (prev et next) de ta liste en faisant gaffe quand tu parcours de ne pas t'emmêler les pinceaux.



    tu as probablement moyen de le faire avec un algo recursif.
    bazar: http://www.improetcompagnie.com/publ...ctacles-6.html

    BÉPO la disposition de clavier francophone, ergonomique et libre: http://bepo.fr/wiki/Accueil

    Emacs Wiki: http://www.emacswiki.org/

    En attente de ce que produira: http://www.pushmid.com

  5. #5
    Membre à l'essai
    Profil pro
    Étudiant
    Inscrit en
    Juillet 2009
    Messages
    15
    Détails du profil
    Informations personnelles :
    Âge : 34
    Localisation : Sénégal

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Juillet 2009
    Messages : 15
    Points : 14
    Points
    14
    Par défaut merci
    merci

  6. #6
    Expert éminent sénior
    Avatar de diogene
    Homme Profil pro
    Enseignant Chercheur
    Inscrit en
    Juin 2005
    Messages
    5 761
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Essonne (Île de France)

    Informations professionnelles :
    Activité : Enseignant Chercheur
    Secteur : Enseignement

    Informations forums :
    Inscription : Juin 2005
    Messages : 5 761
    Points : 13 926
    Points
    13 926
    Par défaut
    Avec une liste simplement chainée et en ne la parcourant qu'une seule fois, on peut utiliser la méthode suivante où invlist sera l'adresse du début de la liste inversée :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    invlist = list
    Si list n'est pas NULL et list->suivant n'est pas NULL :
    Tant que list->suivant n'est pas NULL :
       1- Détacher list->suivant de la liste :
           p = list->suivant
           list->suivant = p->suivant
       2- Et l'insérer en tête de invlist :
           p->suivant = invlist
           invlist = p
    Une dizaine de lignes de code suffisent pour implémenter cette méthode

    Symboliquement, ce processus (pour le début)correspond au schéma ci-dessous
    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
    list----->1 ->2 ->3 ->4 ->NULL
              |
    invlist---^
    
    1 -Enlever list->suivant de la liste
    
    list----->1 ->3 ->4 ->NULL
              |   |
    invlist---^   |
    p--------->2--^
    
    2- Le placer en tête de invlist
    
    list-------->1 ->3 ->4 ->NULL
                 | 
    invlist-->2--^
    Publication : Concepts en C

    Mon avatar : Glenn Gould

    --------------------------------------------------------------------------
    Une réponse vous a été utile ? Remerciez son auteur en cliquant le pouce vert !

  7. #7
    Membre expert Avatar de jabbounet
    Homme Profil pro
    Consultant informatique
    Inscrit en
    Juin 2009
    Messages
    1 909
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 48

    Informations professionnelles :
    Activité : Consultant informatique

    Informations forums :
    Inscription : Juin 2009
    Messages : 1 909
    Points : 3 284
    Points
    3 284
    Par défaut
    ah oui ,

    je l'avais oublié celle là....
    bazar: http://www.improetcompagnie.com/publ...ctacles-6.html

    BÉPO la disposition de clavier francophone, ergonomique et libre: http://bepo.fr/wiki/Accueil

    Emacs Wiki: http://www.emacswiki.org/

    En attente de ce que produira: http://www.pushmid.com

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

    Informations professionnelles :
    Activité : Retraité

    Informations forums :
    Inscription : Décembre 2003
    Messages : 14 512
    Points : 20 985
    Points
    20 985
    Par défaut
    Citation Envoyé par jabbounet Voir le message
    Si tu veux vraiment passer par une fonction sans liste circulaire doublement chainée (cela sera peu être plus couteux)
    l'algo est le suivant:
    Tu crée une nouvelle liste (vide).
    En boucle (ça va te couter très cher si la liste est longue): tu va chercher le dernier élément de ta liste (ça va couter cher si la liste est longue) tu le retire et tu l'insère dans la nouvelle.
    Mais non. Il suffit de la lire l'ancienne liste en séquence et de faire l'insertion en tête dans la nouvelle... La nouvelle liste sera alors inversée...

    Il y a beaucoup à faire avant de sortir la grosse artillerie (liste doublement chainée).
    Pas de Wi-Fi à la maison : CPL

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

Discussions similaires

  1. Réponses: 4
    Dernier message: 22/11/2007, 16h46
  2. Réponses: 1
    Dernier message: 21/04/2007, 16h36
  3. Réponses: 12
    Dernier message: 04/03/2007, 11h43
  4. Tri aléatoire parmis les éléments d'une liste
    Par ahouba dans le forum Access
    Réponses: 2
    Dernier message: 29/06/2006, 18h03
  5. Réponses: 3
    Dernier message: 15/05/2006, 16h09

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