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

SL & STL C++ Discussion :

STL : slist : affichage d'un élément


Sujet :

SL & STL C++

  1. #1
    Membre habitué Avatar de Colbix
    Profil pro
    Développeur Web
    Inscrit en
    Juin 2006
    Messages
    266
    Détails du profil
    Informations personnelles :
    Âge : 38
    Localisation : Belgique

    Informations professionnelles :
    Activité : Développeur Web

    Informations forums :
    Inscription : Juin 2006
    Messages : 266
    Points : 150
    Points
    150
    Par défaut STL : slist : affichage d'un élément
    Voila, la question est surement très bête, mais je voulais savoir comment afficher le Xième élément d'une slist...

    J'ai été voir sur http://www.sgi.com/tech/stl/Slist.html, mais je n'ai pas trouvé...

    Merci d'avance

  2. #2
    Membre du Club
    Profil pro
    Inscrit en
    Novembre 2005
    Messages
    44
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Novembre 2005
    Messages : 44
    Points : 42
    Points
    42
    Par défaut
    Si tu veut accéder au Nième élément, alors tu as sans doute choisi le mauvais conteneur.

    Une liste permets un accès séquentiel, cad pour accéder au nième élément, tu doit parcourir les n-1 éléments précédents.

    Pour un accès aléatoire, utilise plutôt vector.

    Aussi si tu veux réellement une liste, slist n'est pas dans le standard et, à mon avis, apporte peu par rapport à une classique doublement chainée std::list (économie de mémoire : 1 pointeur par élément, économie de calcul : pas grand chose à mon avis)

  3. #3
    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 : 40
    Localisation : France, Moselle (Lorraine)

    Informations professionnelles :
    Activité : Développeur informatique

    Informations forums :
    Inscription : Avril 2003
    Messages : 10 651
    Points : 15 920
    Points
    15 920
    Par défaut
    Au cas où : slist est une extension de la STL SGI, ce n'est pas une classe standard. Pour accéder au x-ème élément d'une liste il faut utiliser std::advance.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    slist<int>::iterator It = l.begin();
    std::advance(It, x);

  4. #4
    Membre du Club
    Profil pro
    Inscrit en
    Novembre 2005
    Messages
    44
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Novembre 2005
    Messages : 44
    Points : 42
    Points
    42
    Par défaut
    Je ne connaissais pas std::advance.

    Dans tout les cas, en interne, il faut parcourir la liste, ce qui est très lent.

    Accès aléatoire rapide (temps constant) => std::vector

    ++

  5. #5
    Membre habitué Avatar de Colbix
    Profil pro
    Développeur Web
    Inscrit en
    Juin 2006
    Messages
    266
    Détails du profil
    Informations personnelles :
    Âge : 38
    Localisation : Belgique

    Informations professionnelles :
    Activité : Développeur Web

    Informations forums :
    Inscription : Juin 2006
    Messages : 266
    Points : 150
    Points
    150
    Par défaut
    Merci pour les infos, pour ce qui est du vector, je n'en au pas besoin ici parceque ma liste va beaucoup changer, dans le cas du vector, si il grandi trop, il sera recopier en mémoir avec un Malloc plus grande. Donc j'ai besoin de la liste pour diminuer les recopiages au détriment du parcours de la liste...

    Je vais essayer avec std::advance(It, x)...

    Je vous tiens au courant !

    A bientôt !

  6. #6
    Expert confirmé
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Décembre 2003
    Messages
    3 549
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Essonne (Île de France)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels

    Informations forums :
    Inscription : Décembre 2003
    Messages : 3 549
    Points : 4 625
    Points
    4 625
    Par défaut
    std:multi)set ?

  7. #7
    Membre habitué
    Profil pro
    Inscrit en
    Octobre 2006
    Messages
    125
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Octobre 2006
    Messages : 125
    Points : 145
    Points
    145
    Par défaut
    Citation Envoyé par Colbix
    Merci pour les infos, pour ce qui est du vector, je n'en au pas besoin ici parceque ma liste va beaucoup changer, dans le cas du vector, si il grandi trop, il sera recopier en mémoir avec un Malloc plus grande. Donc j'ai besoin de la liste pour diminuer les recopiages au détriment du parcours de la liste...

    Je vais essayer avec std::advance(It, x)...

    Je vous tiens au courant !

    A bientôt !
    et tu connais pas la taille a l'avance ?

  8. #8
    Alp
    Alp est déconnecté
    Expert éminent sénior

    Avatar de Alp
    Homme Profil pro
    Inscrit en
    Juin 2005
    Messages
    8 575
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 35
    Localisation : France, Bouches du Rhône (Provence Alpes Côte d'Azur)

    Informations forums :
    Inscription : Juin 2005
    Messages : 8 575
    Points : 11 861
    Points
    11 861
    Par défaut
    On dirait bien que non...
    Si le conteneur doit souvent grandir, souvent "changer de taille", le vector risque d'être vraiment lent comparé à une list.
    De plus, parcourir avec advance est assez pratique, mais c'est en O(n)... Il faut tester les performances du code avec une list et un vector sur une mise en situation.

  9. #9
    Membre éclairé

    Profil pro
    Inscrit en
    Septembre 2006
    Messages
    717
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Septembre 2006
    Messages : 717
    Points : 858
    Points
    858
    Par défaut
    Citation Envoyé par Alp
    Si le conteneur doit souvent grandir, souvent "changer de taille", le vector risque d'être vraiment lent comparé à une list.
    Au contraire, sauf si les objets sont vraiment très lourds à copier, std::vector sera bien plus rapide que std::list. Example :
    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
    #include <ctime>
    #include <iostream>
    #include <vector>
    #include <deque>
    #include <list>
     
    template<typename C>
    double test()
    {
      clock_t t0 = std::clock();
      for(int n = 10; n > 0; --n)
      {
        C c;
        for(int i = 1000000; i > 0; --i)
        {
          c.push_back(i);
        }
      }
      return double(std::clock() - t0)/CLOCKS_PER_SEC;
    }
     
    int main()
    {
      std::cout << "vector:\t" << test< std::vector<int> >() << "s\n";
      std::cout << "deque:\t" << test< std::deque<int> >() << "s\n";
      std::cout << "list:\t" << test< std::list<int> >() << "s\n";
    }
    donne chez moi
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    vector: 0.5s
    deque:  3s
    list:   11s

  10. #10
    Expert confirmé
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Décembre 2003
    Messages
    3 549
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Essonne (Île de France)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels

    Informations forums :
    Inscription : Décembre 2003
    Messages : 3 549
    Points : 4 625
    Points
    4 625
    Par défaut
    Je vois que mon message n'a pas été pris en compte.
    set::set ou std::multiset permettent la recherche et l'insertion n'importe où en temps logarithmique.
    Comme c'est à base de noeuds, il n'y a pas de déplacement à faire quand la capacité ne suffit pas.

  11. #11
    Alp
    Alp est déconnecté
    Expert éminent sénior

    Avatar de Alp
    Homme Profil pro
    Inscrit en
    Juin 2005
    Messages
    8 575
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 35
    Localisation : France, Bouches du Rhône (Provence Alpes Côte d'Azur)

    Informations forums :
    Inscription : Juin 2005
    Messages : 8 575
    Points : 11 861
    Points
    11 861
    Par défaut
    Non mais une fois très grand. C'est pas le fait même de resizer qui est lent, bien sûr que le vector est plus rapide que list dans ce cas.
    Mais s'il faut effectuer des copies ensuites avec un très gros vector, prenant une sacrée place en mémoire, là ca sera dur.
    Enfin, le mieux est de contourner la copie.

    Toujours est-il que le sujet est résolu

  12. #12
    Membre habitué
    Profil pro
    Inscrit en
    Octobre 2006
    Messages
    125
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Octobre 2006
    Messages : 125
    Points : 145
    Points
    145
    Par défaut
    Citation Envoyé par loufoque
    Je vois que mon message n'a pas été pris en compte.
    set::set ou std::multiset permettent la recherche et l'insertion n'importe où en temps logarithmique.
    Comme c'est à base de noeuds, il n'y a pas de déplacement à faire quand la capacité ne suffit pas.
    effectivement loufoque mais dans la mesure ou la question de base est de savoir
    comment acceder au Nieme element
    on suppose que l'ordre d'insertion a son importance ...
    tu vas certainement nous repondre qu'on peut avoir une clef du set qui est un index a increment...

Discussions similaires

  1. Réponses: 9
    Dernier message: 16/03/2007, 02h41
  2. Réponses: 5
    Dernier message: 12/02/2007, 01h19
  3. Réponses: 5
    Dernier message: 26/04/2006, 16h36
  4. Bug d'affichage sur un élément flottant
    Par Sayrus dans le forum Balisage (X)HTML et validation W3C
    Réponses: 1
    Dernier message: 24/12/2005, 02h28
  5. [JComboBox] Affichage de nouveaux éléments
    Par GETah dans le forum Composants
    Réponses: 7
    Dernier message: 21/04/2005, 17h56

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