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 :

Liste , où ça commence au niveau de l'indice?


Sujet :

SL & STL C++

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre éclairé
    Profil pro
    Inscrit en
    Septembre 2006
    Messages
    559
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Septembre 2006
    Messages : 559
    Par défaut Liste , où ça commence au niveau de l'indice?
    Bonjour,

    Une liste, à quel indice ça commence? 0 ou 1?

    Merci d'avance.

  2. #2
    yan
    yan est déconnecté
    Rédacteur
    Avatar de yan
    Homme Profil pro
    Ingénieur expert
    Inscrit en
    Mars 2004
    Messages
    10 035
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 43
    Localisation : France, Ille et Vilaine (Bretagne)

    Informations professionnelles :
    Activité : Ingénieur expert
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Mars 2004
    Messages : 10 035
    Par défaut
    ??une liste n'as pas d'indice.

  3. #3
    Membre éclairé
    Profil pro
    Inscrit en
    Septembre 2006
    Messages
    559
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Septembre 2006
    Messages : 559
    Par défaut
    Arès des tests, j'ai vu que ça commence à 0

  4. #4
    Membre chevronné
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Mai 2006
    Messages
    366
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 42
    Localisation : France, Paris (Île de France)

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

    Informations forums :
    Inscription : Mai 2006
    Messages : 366
    Par défaut
    Citation Envoyé par toutounesan Voir le message
    Arès des tests, j'ai vu que ça commence à 0
    ?? Comme l'a dit Mongaulois, std::list ne permet pas l'accès par indice.

  5. #5
    Alp
    Alp est déconnecté
    Expert confirmé

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

    Informations forums :
    Inscription : Juin 2005
    Messages : 8 575
    Par défaut
    std::list est une liste chainée (doublement). On ne peut pas s'en servir comme un tableau. On peut la parcourir avec un certain nombre d'itérations directement avec std::advance. Mais ce n'est pas son utilisation principale.

  6. #6
    Expert éminent
    Avatar de koala01
    Homme Profil pro
    aucun
    Inscrit en
    Octobre 2004
    Messages
    11 644
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 53
    Localisation : Belgique

    Informations professionnelles :
    Activité : aucun

    Informations forums :
    Inscription : Octobre 2004
    Messages : 11 644
    Par défaut
    Salut,

    La notion d'indice est propre aux structures qui fournissent un accès aléatoire aux données qu'elles contiennent.

    Cela signifie que la complexité permettant de passer d'une donnée quelconque à une autre soit d'office égale à 1.

    Il n'y a dans la STL que le std::vector qui fournisse cette possibilité, toutes les autres classes ont une complexité allant de log N à N.

    Et c'est tout à fait normal car il n'existe, finalement, pas beaucoup de possibilités: Les seules structures réellement utilisables sont
    • les tableaux (acces aléatoire)
    • les piles (système FILO)
    • les files (système FIFO)
    • les listes simplement ou doublement chainées (Acces en N)
    • les arbres binaires (acces en log N) ou non (acces proche du log N)
    • Les variations utilisant plusieurs de ces structures (tables de hashage et autres structures indexées)


    Il est toujours *éventuellement* possible de fournir une fonction (un opérateur, en fait) qui cache la complexité d'accès réelle à l'utilisateur, mais, c'est malgré tout lui rendre un mauvais service, car il croirait avoir affaire à un accès au données aléatoire alors qu'il ne ferait que cacher une boucle d'accès séquentiel du genre de
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
     
    template<class T>
    T& list::opreator[](size_t ind)
    {
        list::iterator it= this->begin();
        for(size_t i=0;i<ind;i++)
            it++;
        return (*it);
    }
    (avec, idéalement, l'envoi d'une erreur si ind est supérieur au nombre d'éléments)
    A méditer: La solution la plus simple est toujours la moins compliquée
    Ce qui se conçoit bien s'énonce clairement, et les mots pour le dire vous viennent aisément. Nicolas Boileau
    Compiler Gcc sous windows avec MinGW
    Coder efficacement en C++ : dans les bacs le 17 février 2014
    mon tout nouveau blog

  7. #7
    Membre Expert
    Avatar de poukill
    Profil pro
    Inscrit en
    Février 2006
    Messages
    2 155
    Détails du profil
    Informations personnelles :
    Âge : 41
    Localisation : France

    Informations forums :
    Inscription : Février 2006
    Messages : 2 155
    Par défaut
    Citation Envoyé par Mongaulois Voir le message
    ??une liste n'as pas d'indice.
    Citation Envoyé par bolhrak Voir le message
    ?? Comme l'a dit Mongaulois, std::list ne permet pas l'accès par indice.
    Effectivement, mais toutounesan est un poil dur d'oreille !
    Merci pour cette explication Koala, très claire, comme d'habitude !

    J'aurai quand même plutôt utilisé advance, puisqu'il est là pour ça!
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    template<class T>
    T& list::operator[](size_t ind)
    {
        list::iterator it = this->begin();
        std::advance(it, ind);
        return (*it);
    }

  8. #8
    Expert éminent
    Avatar de koala01
    Homme Profil pro
    aucun
    Inscrit en
    Octobre 2004
    Messages
    11 644
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 53
    Localisation : Belgique

    Informations professionnelles :
    Activité : aucun

    Informations forums :
    Inscription : Octobre 2004
    Messages : 11 644
    Par défaut
    Citation Envoyé par poukill Voir le message
    Effectivement, mais toutounesan est un poil dur d'oreille !
    Merci pour cette explication Koala, très claire, comme d'habitude !
    Comme d'hab, une simple mise en oeuvre de ma signature
    J'aurai quand même plutôt utilisé advance, puisqu'il est là pour ça!
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    template<class T>
    T& list::operator[](size_t ind)
    {
        list::iterator it = this->begin();
        std::advance(it, ind);
        return (*it);
    }
    Et, honnêtement, comment crois tu qu'il soit géré, std::advance
    A méditer: La solution la plus simple est toujours la moins compliquée
    Ce qui se conçoit bien s'énonce clairement, et les mots pour le dire vous viennent aisément. Nicolas Boileau
    Compiler Gcc sous windows avec MinGW
    Coder efficacement en C++ : dans les bacs le 17 février 2014
    mon tout nouveau blog

Discussions similaires

  1. Réponses: 8
    Dernier message: 19/07/2013, 14h18
  2. Faire commencer un tableau a l'indice 1
    Par agonotrax dans le forum C#
    Réponses: 13
    Dernier message: 10/10/2007, 14h13
  3. Liste déroulante liées sur 3 niveau
    Par DaD92 dans le forum Général JavaScript
    Réponses: 3
    Dernier message: 22/12/2006, 23h48
  4. Liste des langages de haut niveau ?
    Par spirit_epock dans le forum Langages de programmation
    Réponses: 14
    Dernier message: 15/03/2006, 13h25
  5. [Stage] Quel niveau avoir avant de commencer un stage
    Par ghita269 dans le forum Stages
    Réponses: 10
    Dernier message: 22/11/2005, 08h23

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