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 :

QuickSort algo lequel ?


Sujet :

Algorithmes et structures de données

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre confirmé
    Profil pro
    Inscrit en
    Août 2004
    Messages
    94
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Août 2004
    Messages : 94
    Par défaut QuickSort algo lequel ?
    bjr
    j'essai de faire un tri de ma liste avec un algo QuickSort mais au final ma liste n'est pas bien rangée
    j'ai utilisé ces algo là :
    http://www.dailly.info/algorithmes-de-tri/rapide.php
    ou
    1: if r ≤ ℓ + 1 then
    2: return Fini
    3: end if
    4: q ← ℓ, p ← r − 1
    5: v ← a[r − 1].key
    6: while p > q do
    7: while a[p].key ≥ v and p > l do
    8: p ← p − 1
    9: end while
    10: while a[q].key ≤ v and q < r − 1 do
    11: q ← q + 1
    12: end while
    13: if p > q then
    14: ´ Echanger a[p] et a[q]
    15: end if
    16: end while
    17: Echanger a[q] et a[r − 1]
    18: QuickSort(a, ℓ, q)
    19: QuickSort(a, q + 1, r)

    mais ça marche pas donc où récupérer le vrai quickSort ???
    merci d'avance
      0  0

  2. #2
    Rédacteur

    Avatar de Matthieu Brucher
    Profil pro
    Développeur HPC
    Inscrit en
    Juillet 2005
    Messages
    9 810
    Détails du profil
    Informations personnelles :
    Âge : 43
    Localisation : France, Pyrénées Atlantiques (Aquitaine)

    Informations professionnelles :
    Activité : Développeur HPC
    Secteur : Industrie

    Informations forums :
    Inscription : Juillet 2005
    Messages : 9 810
    Par défaut
    Tu l'as fait dans quel langage et où est le code effectif que tu as utilisé ?
      0  0

  3. #3
    Membre confirmé
    Profil pro
    Inscrit en
    Août 2004
    Messages
    94
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Août 2004
    Messages : 94
    Par défaut
    je développe sous borland c++ builder
    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
     
    bool MaClasse::QuickSort(int __fastcall Gauche, int __fastcall Droite)
    {
      bool Fini = false;
     
      if(Droite > Gauche)
      {
        r = Droite;
        l = Gauche;
        q = l;
        p = r;
        AnsiString v = *((AnsiString *)Tableau->Items[r]);
        //AnsiString est un type qui permet de manipuler des chaines de caractères
        while(p > q)
        {
          while( (CompareText(*((AnsiString *)Tableau->Items[p]), v) >= 0) && (p > l) ) 
          //CompareText est une fonction de borland
          {
            p--;
          }
          while( (CompareText(*((AnsiString *)Tableau->Items[q]), v) <= 0) && (q < r) )
          {
            q++;
          }
     
          if(p > q)
          {
            Liste_Lignes->Exchange(p, q);
            //échange la position des pointeurs
          }
        }
        Tableau->Exchange(q, r);
        //échange la position des pointeurs
      }
      else
      {
        Fini = true;
      }
      return Fini;
    }
    ma liste n'est pas ordonée, bref je galère
    merci beaucoup d'avance
      0  0

  4. #4
    Membre chevronné Avatar de Rafy
    Profil pro
    Inscrit en
    Juillet 2005
    Messages
    415
    Détails du profil
    Informations personnelles :
    Âge : 41
    Localisation : France

    Informations forums :
    Inscription : Juillet 2005
    Messages : 415
    Par défaut
    Tu devrai utiliser la librairie standard, il y a des truc déjà tout fait.....
    Crée une liste std::list<int> (car apparemment c'est des int que tu veux trier)
    et il y a une methode sort.
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
     
    std::list<int> MyList;
    //...
    MyList.sort();          // Et voila
    Je ne sais pas si la syntaxe est exacte je ne suis pas devant mon PC.
      0  0

  5. #5
    Membre chevronné
    Profil pro
    Enseignant
    Inscrit en
    Avril 2004
    Messages
    440
    Détails du profil
    Informations personnelles :
    Localisation : France, Puy de Dôme (Auvergne)

    Informations professionnelles :
    Activité : Enseignant

    Informations forums :
    Inscription : Avril 2004
    Messages : 440
    Par défaut
    Citation Envoyé par Rafy
    Je ne sais pas si la syntaxe est exacte je ne suis pas devant mon PC.
    Tu fais des posts par la force de l'esprit ??
      0  0

  6. #6
    Rédacteur

    Avatar de Matthieu Brucher
    Profil pro
    Développeur HPC
    Inscrit en
    Juillet 2005
    Messages
    9 810
    Détails du profil
    Informations personnelles :
    Âge : 43
    Localisation : France, Pyrénées Atlantiques (Aquitaine)

    Informations professionnelles :
    Activité : Développeur HPC
    Secteur : Industrie

    Informations forums :
    Inscription : Juillet 2005
    Messages : 9 810
    Par défaut
    Citation Envoyé par Rafy
    Tu devrai utiliser la librairie standard, il y a des truc déjà tout fait.....
    Crée une liste std::list<int> (car apparemment c'est des int que tu veux trier)
    et il y a une methode sort.
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
     
    std::list<int> MyList;
    //...
    MyList.sort();          // Et voila
    Je ne sais pas si la syntaxe est exacte je ne suis pas devant mon PC.
    Tout à fait d'accord, ça marche avec tout à partir du moment qu'il y a certains opérateurs de comparaisons définis.
      0  0

  7. #7
    Membre confirmé
    Profil pro
    Inscrit en
    Août 2004
    Messages
    94
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Août 2004
    Messages : 94
    Par défaut
    //AnsiString est un type qui permet de manipuler des chaines de caractères
    !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
    chaines de caractères est beaucoup plus lourd que int

    mais merci pour l'info sur la déclaration d'un tableau de int (je savais pas comment en faisait)
      0  0

  8. #8
    Rédacteur
    Avatar de Laurent Gomila
    Profil pro
    Développeur informatique
    Inscrit en
    Avril 2003
    Messages
    10 651
    Détails du profil
    Informations personnelles :
    Âge : 41
    Localisation : France, Moselle (Lorraine)

    Informations professionnelles :
    Activité : Développeur informatique

    Informations forums :
    Inscription : Avril 2003
    Messages : 10 651
    Par défaut
    La suite ici :

    http://www.developpez.net/forums/vie....php?p=2136120

    Merci d'éviter de dupliquer les sujets à l'avenir.
      0  0

Discussions similaires

  1. problème avec un algo quicksort
    Par aaronlbk dans le forum C++
    Réponses: 3
    Dernier message: 14/08/2014, 11h31
  2. Algo d'arrangement (style quicksort)
    Par haribooo dans le forum Algorithmes et structures de données
    Réponses: 1
    Dernier message: 31/08/2009, 01h14
  3. complexité de l'algo QuickSort
    Par t-student dans le forum Algorithmes et structures de données
    Réponses: 8
    Dernier message: 17/03/2008, 18h24
  4. algo de merge et quicksort
    Par jack_spyrow dans le forum Algorithmes et structures de données
    Réponses: 2
    Dernier message: 22/06/2006, 12h21
  5. Cherche l'algo crc 16 bits
    Par icepower dans le forum Algorithmes et structures de données
    Réponses: 2
    Dernier message: 21/08/2002, 13h27

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