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 :

Sort et pair <>


Sujet :

C++

  1. #1
    Membre régulier
    Profil pro
    Inscrit en
    Décembre 2007
    Messages
    560
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Décembre 2007
    Messages : 560
    Points : 71
    Points
    71
    Par défaut Sort et pair <>
    Bonjour,

    Je cherche à ranger une pair de valeur pair <double , cv::Point2d>, présent dans un vecteur:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    vector<pair<double,Point2d> > vCs;
    Je remplis donc dans un premier temps le vecteur de pair et j'essaye de trier:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    sort(vCs.begin(), vCs.end());
    J'ai créé auparavant la fonction de comparaison des pair:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    inline bool operator<(const pair<double,cv::Point2d>  &A, const pair<double,cv::Point2d> &B)
    {
        return A.first < B.first;
    }

    Mais le compilateur me renvoie une erreur:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    /usr/include/c++/4.6/bits/stl_pair.h:209:62: error: no match for 'operator<' in '__x.std::pair<double, cv::Point_<double> >::second < __y.std::pair<double, cv::Point_<double> >::second'
    Pourtant j'ai bien définie ma fonction de comparaison operator<...
    Quelle serait la raison de cette erreur?

    Si quelqu'un pouvait m'aider. D'avance merci.

  2. #2
    Membre éprouvé

    Profil pro
    Inscrit en
    Décembre 2008
    Messages
    533
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Décembre 2008
    Messages : 533
    Points : 1 086
    Points
    1 086
    Par défaut
    [edit]
    Pour une raison mystérieuse (probablement l'ordre d'inclusion des headers) ta surcharge de operator< n'est pas prise en compte, ou pas à temps. Donc pair essaie de tester les first entre eux PUIS les second, comme il est spécifié dans la STL : http://en.cppreference.com/w/cpp/uti...r/operator_cmp

    Il vaudrait mieux fournir directement à ton sort un foncteur pour le tri :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    bool comp(const pair<double,cv::Point2d>  &A, const pair<double,cv::Point2d> &B)
    {
        return A.first < B.first;
    }
    sort(vCs.begin(), vCs.end(), comp);

  3. #3
    Membre régulier
    Profil pro
    Inscrit en
    Décembre 2007
    Messages
    560
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Décembre 2007
    Messages : 560
    Points : 71
    Points
    71
    Par défaut
    Le message complet c'est :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    Tracker.cpp:382:77: error: no matching function for call to 'sort(std::vector<std::pair<double, cv::Point_<double> > >::iterator, std::vector<std::pair<double, cv::Point_<double> > >::iterator, <unresolved overloaded function type>)'
    Tracker.cpp:382:77: note: candidates are:
    /usr/include/c++/4.6/bits/stl_algo.h:5394:5: note: template<class _RAIter> void std::sort(_RAIter, _RAIter)
    /usr/include/c++/4.6/bits/stl_algo.h:5430:5: note: template<class _RAIter, class _Compare> void std::sort(_RAIter, _RAIter, _Compare)

    Je sais que l'on ne peut pas comparer les cv::Point2d mais dans ma fonction de compare, je ne compare pas les cv::Point2d mais les valeurs double.

  4. #4
    Membre émérite
    Profil pro
    Inscrit en
    Novembre 2004
    Messages
    2 764
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Novembre 2004
    Messages : 2 764
    Points : 2 705
    Points
    2 705
    Par défaut
    Citation Envoyé par cob59 Voir le message
    Il vaudrait mieux fournir directement à ton sort un foncteur pour le tr
    Pourquoi ?

  5. #5
    Membre éprouvé

    Profil pro
    Inscrit en
    Décembre 2008
    Messages
    533
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Décembre 2008
    Messages : 533
    Points : 1 086
    Points
    1 086
    Par défaut
    Citation Envoyé par oodini Voir le message
    Pourquoi ?
    Ça lui éviterait de surcharger/spécialiser des morceaux de la STL, ce qui apparemment lui pose des problèmes.

    En plus ce serait un moyen de clarifier son code en exprimant son critère de tri via le nom de son foncteur. operator< a un sens arithmétique précis et compréhensible sur des scalaires, mais sur des types composés comme std::pair c'est tout de suite moins clair. Donc autant utiliser des prédicats.

Discussions similaires

  1. StringGrid sort
    Par clovis dans le forum C++Builder
    Réponses: 4
    Dernier message: 20/10/2004, 21h46
  2. sorte de valeur par defaut
    Par sampq dans le forum Langage SQL
    Réponses: 2
    Dernier message: 25/07/2003, 11h59
  3. xsl:sort
    Par Pierre63 dans le forum XMLRAD
    Réponses: 2
    Dernier message: 03/07/2003, 12h37
  4. JBuilder 7 personnal sort à chaque save
    Par Hannouz dans le forum JBuilder
    Réponses: 4
    Dernier message: 17/12/2002, 22h53
  5. Réponses: 4
    Dernier message: 30/06/2002, 20h23

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