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 liste doublement chainee bubble


Sujet :

C

  1. #1
    Membre confirmé

    Profil pro
    Inscrit en
    Janvier 2008
    Messages
    786
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Janvier 2008
    Messages : 786
    Points : 602
    Points
    602
    Par défaut tri liste doublement chainee bubble
    Bonjour j'essaie de trier ma liste doublement chainee avec la methode bubble mais sa merde ...

    Voici mon code :
    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
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
     
    void            reverse_elt(t_file *elt1, t_file *elt2)
    {
      t_file        *temp;
     
      temp = elt1;
     
      elt1->next = elt2->next;
      elt1->previous = elt2->previous;
     
      if (elt2->previous != NULL)
        elt2->previous->next = elt1;
      if (elt2->next != NULL)
        elt2->next->previous = elt1;
     
     
      elt2->next = temp->next;
      elt2->previous = temp->previous;
      if (temp->next != NULL)
        temp->next->previous = elt2;
      if (temp->previous != NULL)
        temp->previous->next = elt2;
    }
     
    t_file          *sort_result(t_file *l_of_file, int sens)
    {
      t_file        *master;
      t_file        *slave;
     
      master = l_of_file;
      slave = l_of_file->next;
      while (master->next != NULL)
        {
          while (slave != NULL)
            {
              if (my_strcmp(master->name, slave->name) > 0)
                {
                  reverse_elt(master, slave);
                }
              slave = slave->next;
            }
          master = master->next;
          slave = master;
        }
      return (go_to_begin(master));
    }
    Sa merde sur le reverse elt je pense mais je ne vois pas ou !

    merci de votre aide

  2. #2
    Expert éminent sénior
    Avatar de Médinoc
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Septembre 2005
    Messages
    27 369
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 40
    Localisation : France

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Septembre 2005
    Messages : 27 369
    Points : 41 519
    Points
    41 519
    Par défaut
    Lors de l'échange de deux éléments d'une liste doublement chaînée, il faut faire un traitement particulier dans le cas où ces deux éléments sont contigus.
    SVP, pas de questions techniques par MP. Surtout si je ne vous ai jamais parlé avant.

    "Aw, come on, who would be so stupid as to insert a cast to make an error go away without actually fixing the error?"
    Apparently everyone.
    -- Raymond Chen.
    Traduction obligatoire: "Oh, voyons, qui serait assez stupide pour mettre un cast pour faire disparaitre un message d'erreur sans vraiment corriger l'erreur?" - Apparemment, tout le monde. -- Raymond Chen.

  3. #3
    Membre confirmé

    Profil pro
    Inscrit en
    Janvier 2008
    Messages
    786
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Janvier 2008
    Messages : 786
    Points : 602
    Points
    602
    Par défaut re
    Ok c'est bien ce que je pensais ... sinon ca te semble valide ???

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

Discussions similaires

  1. [Débutant] liste doublement chainee
    Par newbie2012 dans le forum Langages
    Réponses: 2
    Dernier message: 18/02/2012, 17h43
  2. liste doublement chainee
    Par don1design dans le forum Débuter
    Réponses: 1
    Dernier message: 02/07/2010, 11h04
  3. Trier une liste doublement chainee pr tri bulle
    Par saturn1 dans le forum Contribuez
    Réponses: 0
    Dernier message: 13/12/2009, 23h14
  4. List doublement Chainee
    Par bonomsoleil dans le forum C++
    Réponses: 4
    Dernier message: 17/05/2007, 18h10
  5. Réponses: 20
    Dernier message: 22/03/2006, 14h00

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