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 :

methode de classe pour sort


Sujet :

SL & STL C++

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre du Club
    Profil pro
    Inscrit en
    Avril 2007
    Messages
    7
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2007
    Messages : 7
    Par défaut methode de classe pour sort
    Bonjour,
    le titre n'est peut être pas très explicite mais mon problème est le suivant:
    j'ai une classe hypergraph composé de deux conteneurs différents dont un est un vector<set<string> > .Je dois trier ce conteneur de différentes façons (taille,fréquence de ses éléments, ..). Pour la taille pas de problème, j'ai utilisé une fonction friend de cette façon :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    bool taille_croissante(const set<string>& s1, const set<string>& s2)
    {
       if (s1.size() < s2.size())
          return true;
       else
          return false;
    }
    et je l'utilise comme ceci :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    sort(test.hyperaretes.begin(),test.hyperaretes.end(),taille_croissante);
    Mais voila, pour ce qui est des fréquences je ne vois pas comment faire car pour les calculer, je dois me servir du deuxième conteneur de ma classe hypergraph et je pense dont utiliser une méthode. J'ai alors essayé de faire :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    bool hypergraph::frequence_croissante(const set<string>& s1, const set<string>& s2)
    {
    ...
    }
    et je l'appelle comme ceci :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    sort(test.hyperaretes.begin(),test.hyperaretes.end(),test.frequence);
    J'ai une erreur à la compilation:

    232 C:\programmation\projet\vect.cpp no matching function for call to `sort(__gnu_cxx::__normal_iterator<std::set<std::string, std::less<std::string>, std::allocator<std::string> >*, std::vector<std::set<std::string, std::less<std::string>, std::allocator<std::string> >, std::allocator<std::set<std::string, std::less<std::string>, std::allocator<std::string> > > > >, __gnu_cxx::__normal_iterator<std::set<std::string, std::less<std::string>, std::allocator<std::string> >*, std::vector<std::set<std::string, std::less<std::string>, std::allocator<std::string> >, std::allocator<std::set<std::string, std::less<std::string>, std::allocator<std::string> > > > >, <unknown type>)'

    Si vous voyez mon problème ou si je n'est pas été assez clair n'hésitez pas.

    Merci de votre aide

  2. #2
    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
    Par défaut
    bind(&hypergraph::frequence_croissante, test) ou alors tu fais ton foncteur à la main

  3. #3
    Membre éclairé
    Profil pro
    Inscrit en
    Juillet 2004
    Messages
    410
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juillet 2004
    Messages : 410
    Par défaut
    test en déclarant hypergraph::frequence_croissante en static?

  4. #4
    Membre du Club
    Profil pro
    Inscrit en
    Avril 2007
    Messages
    7
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2007
    Messages : 7
    Par défaut
    Merci de vos réponses.

    J'avais momentanément fais quelque chose de pas très propre voir très crade : une nouvelle méthode dans ma classe faisant un tri maison avec le test concernant les fréquences et cela fonctionne mais pour mettre quelque chose de plus propre. J'ai donc testé les deux méthodes.

    Pour la première je ne connais pas de fonction bind. Je suppose que tu veux parler de bind1st ou de bind2nd mais dans ce cas ce n'est pas les bons paramètres si?

    Pour la deuxième méthode, j'ai une nouvelle erreur de compilation dûe au fait que j'utilise mes hyperarêtes dans une fonction membre static mais je ne vois quand même pas ce qui changerait le problème en passant par le static.

  5. #5
    Membre Expert

    Profil pro
    Inscrit en
    Juin 2006
    Messages
    1 294
    Détails du profil
    Informations personnelles :
    Localisation : Royaume-Uni

    Informations forums :
    Inscription : Juin 2006
    Messages : 1 294
    Par défaut
    Salut,

    Tu peux par exemple faire :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    sort(test.hyperaretes.begin(),test.hyperaretes.end(),&hypergraph::frequence_croissante);
    Et oui il faut que hypergraph::frequence_croissante soit statique.

    Si tu veux passer des paramètres il faut que tu passes par un foncteur, regarde par ex cette entrée de la FAQ.

    Une autre solution solution est d'utiliser Boost.Bind (je pense que c'est ça que suggère loufoque) pour construire un foncteur à la volée.

    MAT.

  6. #6
    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
    Salut.
    Tu peut aussi regarder ici
    http://r0d.developpez.com/articles/algos-stl/

Discussions similaires

  1. Classe pour la création d'un graphe xy
    Par Bob dans le forum MFC
    Réponses: 24
    Dernier message: 03/12/2009, 17h20
  2. Réponses: 7
    Dernier message: 08/01/2005, 13h24
  3. Visibilité de methodes dans Classe de Class
    Par Math75 dans le forum C++
    Réponses: 9
    Dernier message: 28/09/2004, 12h48
  4. Méthode ou fonction pour connaitre utilisateur
    Par Madmac dans le forum Administration système
    Réponses: 6
    Dernier message: 23/09/2004, 17h47
  5. Diagramme des classes pour l'interface visuel
    Par robv dans le forum Diagrammes de Classes
    Réponses: 2
    Dernier message: 25/06/2004, 10h50

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