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 :

Passer en paramètre de sort une fonction membre


Sujet :

C++

  1. #1
    Futur Membre du Club
    Homme Profil pro
    Étudiant
    Inscrit en
    Mai 2014
    Messages
    3
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Loire Atlantique (Pays de la Loire)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Mai 2014
    Messages : 3
    Par défaut Passer en paramètre de sort une fonction membre
    Bonjour,

    Je sais que des réponses ont déjà été apporté à des questions similaires, mais elles ne m'ont pas permis de régler mon problème.

    Je cherche à trier un vector d'entier (ce sont des index d'objet) d'après la valeur allouée à leurs index dans un tableau stocké dans une classe "Solveur". J'aimerais le faire avec la fonction sort de <algorithm> pour aller plus vite.

    J'ai donc créé un comparateur d'index dans la classe en question, mais je n'arrive pas à passer ce comparateur en paramètre de sort.

    Voilà des fragments de mon code...

    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
     
    bool Solveur::comp_ordo(int i, int j)
    {
    	return cplex.getValue(C_jk[i][0]) < cplex.getValue(C_jk[j][0]);
    }
     
    void Solveur::fct(){
     
    ...
     
    vector<int> job_ordo = vector<int>(nJ);
    for (int j = 0; j < nJ; j++) job_ordo[j] = j;
     
    sort(job_ordo.begin(), job_ordo.end(), &(this->comp_ordo)); // &(this->comp_ordo) ne fonctionne pas
     
    ...
    }
    Voilà, si quelqu'un pouvait m'aider...
    Merci!!!

  2. #2
    Membre éprouvé
    Profil pro
    Inscrit en
    Novembre 2004
    Messages
    2 766
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Novembre 2004
    Messages : 2 766
    Par défaut
    Passe une expression lambda.

  3. #3
    Futur Membre du Club
    Homme Profil pro
    Étudiant
    Inscrit en
    Mai 2014
    Messages
    3
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Loire Atlantique (Pays de la Loire)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Mai 2014
    Messages : 3
    Par défaut
    Excuse-moi, je ne vois pas ce que tu veux dire... Tu aurais un exemple?

  4. #4
    Expert éminent

    Femme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Juin 2007
    Messages
    5 202
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : France, Essonne (Île de France)

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

    Informations forums :
    Inscription : Juin 2007
    Messages : 5 202
    Par défaut
    La base de ton problème, c'est que comp_ordo n'est pas une fonction du type attendu par la fonction sort.

    sort demande une chose utilisable comme une fonction bool (T, T), avec T le type des valeurs à trier (formellement, std::iterator_traits<decltype(jordo.begin())>::value_type).
    Mais ta fonction a pour signature bool Solveur::(int, int).

    La solution théorique est de passer par un foncteur, c'est à dire un objet qui sera appelable comme une fonction (en lui donnant l'opérateur de fonction adapté).
    La solution pratique la plus simple est effectivement de passer par une expression lambda, qui permet de créer simplement un tel foncteur.

    par exemple
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    sort(
        job_ordo.begin(),
        job_ordo.end(),
        [&this](int a, int b) { return this->comp_ordo(a, b); }
    );
    le troisième argument défini un objet ayant pour membre une référence sur this, et dont l'operator () est défini par (int a, int b) { return this->comp_ordo(a, b); }.


    Un peu de documentation pour les détails: la page de cppreference.com.

  5. #5
    Futur Membre du Club
    Homme Profil pro
    Étudiant
    Inscrit en
    Mai 2014
    Messages
    3
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Loire Atlantique (Pays de la Loire)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Mai 2014
    Messages : 3
    Par défaut
    Merci, ça fonctionne!!
    Je vais renseigner un peu plus sur les foncteurs pour la suite

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

    Informations professionnelles :
    Activité : aucun

    Informations forums :
    Inscription : Octobre 2004
    Messages : 11 636
    Par défaut
    Salut,
    Citation Envoyé par BlastVoy Voir le message
    Merci, ça fonctionne!!
    Je vais renseigner un peu plus sur les foncteurs pour la suite
    Bah, ca, c'est relativement simple : un foncteur est une classe ou une structure qui n'expose qu'un opérateur ().

    Cela prend généralement la forme de
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    struct MonFoncteur{
        TypeDeRetour operator() (/* paramètres éventuels */) const{
     
        }
    };
    A partir de là, on peut jouer sur les mots et parler de unary-functor, de binary-functor ou de predicate. Un predicate est un foncteur dont le type de retour de l'opérateur () est d'office un bool. Un unary functor est un foncteur pour lequel l'opérateur s'attend à recevoir un (et un seul ) paramètre et un binary-functor est un foncteur dont l'opérateur () s'attend à recevoir deux paramètres.

    Dans le cas présent, un foncteur prendrait une forme proche de
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    struct MonFoncteur{
        MonFoncteur(Solveur const & s):s{s}{}
        Solver const & s
        bool operator()(int i, int j) const{
            return s.getValue(C_jk[i][0]) < s.getValue(C_jk[j][0]);
        }
    };
    et ton appel à sort prendrait la forme de
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    /* soit s est ton solveur */
    std::sort(s.begin(), s.end(), MonFoncteur{s});
    Aussi simple que cela
    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

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

Discussions similaires

  1. Réponses: 4
    Dernier message: 14/09/2006, 12h25
  2. Réponses: 3
    Dernier message: 16/05/2006, 18h22
  3. Réponses: 14
    Dernier message: 16/05/2006, 11h26
  4. Réponses: 4
    Dernier message: 01/12/2005, 12h33
  5. Réponses: 3
    Dernier message: 28/11/2005, 12h15

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