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 :

find() de std::set avec fonction de comparaison


Sujet :

SL & STL C++

  1. #1
    Membre émérite
    Avatar de Biglo
    Profil pro
    Inscrit en
    Juillet 2002
    Messages
    537
    Détails du profil
    Informations personnelles :
    Localisation : France, Moselle (Lorraine)

    Informations forums :
    Inscription : Juillet 2002
    Messages : 537
    Par défaut find() de std::set avec fonction de comparaison
    Bonsoir,

    Un petit problème m'empêche d'avancer. J'ai un "set" d'objets défini ainsi :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    set<MaClasse, ClasseComparaison> commands;
    J'aimerais, sur cet ensemble, réaliser un find(const string&). Pour cela, j'ai créé un operator==(const string&) dans ma classe. Bien entendu, ça ne fonctionne pas.

    Y a-t-il un moyen de spécifier la fonction de comparaison à utiliser pour find() ?

    Merci d'avance

  2. #2
    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
    La fonction std::set::find utilise forcément la même comparaison que celle du set. C'est la raison d'être du set d'offrir de bonnes perfs de recherche selon cette fonction(O(ln n)), et celle ci uniquement, et donc, selon la philosophie STL, on n'a pas défini dans l'interface du set de fonctions membre qui iraient à l'encontre de ce pour quoi le set est fait.

    Si tu veux faire ça :
    - Tu te moques des perfs, et tu utilises std::find qui te trouvera ça en O(n)
    - Sinon, il te faut une autre structure de données:
    - A la main, tu peux avoir deux conteneurs que tu synchronise
    - Il y a boost::multi_index pour gérer ce genre de chose
    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.

  3. #3
    Membre émérite
    Avatar de Biglo
    Profil pro
    Inscrit en
    Juillet 2002
    Messages
    537
    Détails du profil
    Informations personnelles :
    Localisation : France, Moselle (Lorraine)

    Informations forums :
    Inscription : Juillet 2002
    Messages : 537
    Par défaut
    Merci pour la réponse.

    Les performances sont importantes dans mon cas, c'est vrai que je n'avais pas pensé au fonctionment de find()...

    J'oublie boost::multi_index, mais merci de me l'avoir proposé. En fait, j'ai oublié de préciser que je n'ai pas besoin de clés d'un type autre que chaîne de caractères.

    N'ayant pas beaucoup de temps à m'attarder sur ce problème, j'ai changé de conteneur :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    map<const char*, MaClasse, fctComparaison> commands;
    Cela fait une petite redondance car la clé est aussi présente dans mes objets. Mais cela me permet de faire des recherches avec une chaîne de caractères.

    Dans mon cas, je suppose qu'une table de hashage serait la mieux adaptée. Mais ne connaissant pas, je pense que ça me prendrait trop de temps à implémenter. :

    L'utilisation de "map" est-elle ridicule ici? Je ne vois pas d'autre conteneur simple me permettant de faire ceci.

  4. #4
    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
    Dans tous les cas n'utilise pas const char *, il faut que les objets stockés soient copiables (-> std::string).

Discussions similaires

  1. Tri avec fonction de comparaison personnalisée (Python 3)
    Par MorganStern dans le forum Général Python
    Réponses: 4
    Dernier message: 28/01/2010, 12h22
  2. Problème std::set avec une structure
    Par DeathMixer dans le forum C++
    Réponses: 4
    Dernier message: 03/10/2009, 01h05
  3. [VBA-E] Pb Comparaison De Deux Colonnes Avec Fonction If
    Par gromorice dans le forum Macros et VBA Excel
    Réponses: 6
    Dernier message: 23/03/2007, 05h57
  4. Recherche "étoilée" avec std::set
    Par guejo dans le forum MFC
    Réponses: 2
    Dernier message: 06/05/2004, 13h28
  5. STL : std::set problème avec insert ...
    Par Big K. dans le forum MFC
    Réponses: 13
    Dernier message: 08/11/2003, 01h02

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