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 :

mais que fait upper_range() dans un multimap?


Sujet :

C++

  1. #1
    Membre averti
    Inscrit en
    Septembre 2004
    Messages
    25
    Détails du profil
    Informations forums :
    Inscription : Septembre 2004
    Messages : 25
    Par défaut mais que fait upper_range() dans un multimap?
    Bonjour.
    J'ai un problème avec la fonction membre de la classe multimap dont voici
    le soit disant role selon la norme:
    iterator upper_bound(const key_type& x);
    Returns an iterator to the last element whose key is less than or equal to x. If no such element exists, then end() is returned.
    Apparamment, cette fonction me retourne l' iterateur suivant l'iterateur sur la derniere paire dont la clé est inférieure ou égale a la clé passee en argument.
    C'est à dire que si ma clé est presente il ne me fournit pas un itérateur sur une paire ayant cette clé.
    J'utilise BorlandC++Compiler5.5.
    Merci si vous en savez plus.

  2. #2
    mat.M
    Invité(e)
    Par défaut
    ?? Normalement d'après la doc , si l'élément n'existe pas c'est end() qui est renvoyé.

    Apparamment, cette fonction me retourne l' iterateur suivant l'iterateur sur la derniere paire dont la clé est inférieure ou égale a la clé passee en argument.
    Logique : l'élément selon la clé const key_type& x n'est pas trouvé dans la liste

  3. #3
    Membre averti
    Inscrit en
    Septembre 2004
    Messages
    25
    Détails du profil
    Informations forums :
    Inscription : Septembre 2004
    Messages : 25
    Par défaut
    ??? mat.M a dit:
    ?? Normalement d'après la doc , si l'élément n'existe pas c'est end() qui est renvoyé.
    Logique : l'élément selon la clé const key_type& x n'est pas trouvé dans la liste
    J'ai justement un élément avec la clé recherchée!!?

  4. #4
    Membre averti
    Inscrit en
    Septembre 2004
    Messages
    25
    Détails du profil
    Informations forums :
    Inscription : Septembre 2004
    Messages : 25
    Par défaut
    Apparemment je me suis mal exprimé alors un exemple:
    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
     
    #include<iostream>
    #include<map>
    using namespace std;
    template<class T,class U> void affiche(multimap<T,U> m) {
        cout<<"le map contient "<<m.size()<<" elements:\n";
        multimap<T,U>::iterator it;
        for(it=m.begin();it!=m.end();it++) { 
                 cout<<(*it).first<<" "<<(*it).second<<endl;
        }
    }
     
    main(){
           multimap<int,char> m;
           m.insert(make_pair(4,'a'));
           m.insert(make_pair(2,'z'));
           m.insert(make_pair(4,'b'));m.insert(make_pair(8,'b'));
          multimap<int,char>:: iterator it;
          affiche(m);
          it=m.upper_bound(4);
          if(it!=m.end())  cout<<"\nessai:"<<(*it).first<<" "<<(*it).second<<endl;
    }
    Cela me donne:
    essai:8 b
    alors que je pensais que cela me donnerait
    essai:4 b
    Ce que je souhaiterai savoir c'est si cela est spécifique à mon compilo

  5. #5
    mat.M
    Invité(e)
    Par défaut
    euuhhh dans l'exemple donné un "iterateur" iterator est utilisé mais on ne boucle pas;
    C'est normal docteur ?

  6. #6
    Membre averti
    Profil pro
    Inscrit en
    Janvier 2003
    Messages
    31
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Janvier 2003
    Messages : 31
    Par défaut
    En tout cas, ton compilateur a raison de renvoyer (8,b). Peut-être est-ce la doc qui est mal rédigée. Voici la spécification officielle (C++ Standard, 1998) :
    map::upper_bound( k ) returns an iterator pointing to the first element with a key greater than k

  7. #7
    Membre averti
    Inscrit en
    Septembre 2004
    Messages
    25
    Détails du profil
    Informations forums :
    Inscription : Septembre 2004
    Messages : 25
    Par défaut
    ok merci!!!
    Effectivement la doc est mal rédigée.De plus Dellannoy dans son bouquin
    a également (une fois de plus!) tort.
    En tout cas la c'est clair: http://www.dinkumware.com/manuals/re...p::upper_bound

  8. #8
    Rédacteur/Modérateur
    Avatar de JolyLoic
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Août 2004
    Messages
    5 463
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 50
    Localisation : France, Yvelines (Île de France)

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

    Informations forums :
    Inscription : Août 2004
    Messages : 5 463
    Par défaut
    En fait, c'est assez logique : Tout comme end retourne l'élément juste après le dernier, upper_bound retourne l'élément juste après le dernier à être égal à la clef qu'on lui passe. Comme ça, on peut itérer sans problème de lower_bound à upper_bound
    Ma session aux Microsoft TechDays 2013 : Développer en natif avec C++11.
    Celle des Microsoft TechDays 2014 : Bonnes pratiques pour apprivoiser le C++11 avec Visual C++
    Et celle des Microsoft TechDays 2015 : Visual C++ 2015 : voyage à la découverte d'un nouveau monde
    Je donne des formations au C++ en entreprise, n'hésitez pas à me contacter.

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

Discussions similaires

  1. Mais que fait IE7 ?
    Par dinguot dans le forum Général JavaScript
    Réponses: 2
    Dernier message: 18/07/2007, 12h39
  2. [Tableaux] Mais que fait cette condition exactement?
    Par pierrot10 dans le forum Langage
    Réponses: 5
    Dernier message: 21/09/2006, 12h36
  3. [ Eclipse3.0 ] Mais que fait le debogueur ?
    Par Bz dans le forum Eclipse Java
    Réponses: 5
    Dernier message: 07/07/2005, 14h31
  4. Mais que fait static ???
    Par elsargento dans le forum C
    Réponses: 4
    Dernier message: 25/09/2003, 09h55

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