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 sur un vector qui contient une structure


Sujet :

SL & STL C++

Vue hybride

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

    Informations forums :
    Inscription : Novembre 2007
    Messages : 10
    Par défaut find sur un vector qui contient une structure
    Bonsoir,

    J'ai déja réussit (en cherchant) à faire un find de la STL sur un vector de string, et maintenant, je voudrais faire une modification dans laquelle le vector contient non pas une seule string, mais une structure de 3 string.
    Et la, j'ai beau faire, je n'arrive pas à trouver la syntaxe à appliquer.

    Sur mon vector de string, j'avais fait ceci :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    if (find(index.begin(), index.end(), nom ) == index.end() )
    {  /* si pas trouvé */  }
    else
    {  /* si trouvé */  }
    maintenant, mon vector est devenu ceci :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    struct IndexBloc
    {
        string rang;
        string nom;
        string valeur;
    };
     
    std::vector<IndexBloc> index;
    et je voudrias faire un find sur le champ nom, et je ne trouve pas la syntaxe.

    Voila les syntaxes que j'ai essayé (sans succès hélas) dans mon find.

    index::nom.begin()
    index.nom.begin()
    index->nom.begin()

    Si quelqu'un peut m'éclairer, je l'en remercie d'avance, car j'ai beau chercher, je n'arrive pas à dénicher l'info.

  2. #2
    Membre éprouvé
    Étudiant
    Inscrit en
    Octobre 2007
    Messages
    189
    Détails du profil
    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Octobre 2007
    Messages : 189

  3. #3
    Membre Expert
    Avatar de poukill
    Profil pro
    Inscrit en
    Février 2006
    Messages
    2 155
    Détails du profil
    Informations personnelles :
    Âge : 41
    Localisation : France

    Informations forums :
    Inscription : Février 2006
    Messages : 2 155
    Par défaut
    Cet article est plus complet !

  4. #4
    Membre habitué
    Profil pro
    Inscrit en
    Novembre 2007
    Messages
    10
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Novembre 2007
    Messages : 10
    Par défaut
    Entre temps, je suis allé regarder la déclaration du template dans le stl_algo.h, mais sans résultat.

    Merci à tous deux, mais je ne suis pas tout à fait sur de ce que je dois comprendre, corrigez moi si je me trompe :

    >> pour résoudre mon problème, je ne dois pas me servir de find, qui est reservé aux cas simples (tel qu'un vector ou un tableau C d'un type non composé), mais dès qu'il faut préciser sur quel élément le test doit se faire, il faut se servir de find_if pour expliquer à cette brave STL ce qu'on souhaite ?

    C'est ca, j'ai bon ? (si oui, alors je risquait de chercher encore longtemps du coté de find )

    Bon je vais essayer d'aller faire fonctionner ca, et si ca marche, je reviens vous le dire (et si ca marche pas, je reviens aussi )

  5. #5
    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
    Disons que find recherche par égalité. Donc, si tu veux trouver une structure, il faut que tu lui passe une structure à laquelle elle doit être égale. find_if lui recherche par prédicat, tu peut donc lui indiquer n'importe quelle condition de recherche, comme par exemple une égalité partielle.

    A noter que si tu dois faire beaucoup de recherches par nom, vector+find n'est probablement pas la meilleure structure, car la recherche se fait en temps linéaire. Tu pourrais faire un map<string, IndexBloc> pour une recherche en temps logarithmique.
    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.

  6. #6
    Membre très actif
    Profil pro
    professeur des universités à la retraite
    Inscrit en
    Août 2008
    Messages
    364
    Détails du profil
    Informations personnelles :
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : professeur des universités à la retraite

    Informations forums :
    Inscription : Août 2008
    Messages : 364
    Par défaut
    Il est probable que tu devrais en effet utiliser plutôt un map comme cela t'a été suggéré.
    Toutefois j'ai essayé de faire quelque chose avec la structure telle quelle, en utilisant la fonction find_if() prenant en (dernier) argument un 'objet fonctionnel' que j'ai préalablement défini (trouve()):

    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
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
    57
    58
     
    #include <iostream>
    #include <functional>
    #include <vector>
    #include <algorithm>
    #include <string>
    using namespace std;
     
     
    struct IndexBloc
    {
      string rang;
      string nom;
      string valeur;
    };
     
     
    // définition d'un objet fonctionnel (function object) qui servira d'argument à find_if
    class trouve
    {
      string const & s;
      public:
        trouve(string const & ss):s(ss) {}
        bool operator()(IndexBloc const & ib) const { return ib.nom == s; }
    };
     
    //--------------------------------------------------------------------------
     
    int main () 
    { 
      std::vector<IndexBloc> index;
     
      // création de trois structures
      IndexBloc a,b,c;
      // remplissage partiel d'icelles
      a.nom = "Jules";
      a.valeur = "immense";
      b.nom = "Simon";
      c.nom = "Isabelle";
      // remplissage du vecteur
      index.push_back(a);
      index.push_back(b);
      index.push_back(c);
     
      // création d'un itérateur pour le vecteur
      vector<IndexBloc>::const_iterator iter;
     
      //après exécution de la ligne qui suit iter pointe vers la première structure dont
      // le champ nom est "Jules", s'il en existe une
      // sinon iter pointe vers index.end() (la position qui suit le dernier élément du vecteur)
      iter = find_if(index.begin(), index.end(), trouve("Jules"));
     
      // exploitation possible :
      if( iter != index.end())
        cout << "valeur de " <<  (*iter).nom << ": " << (*iter).valeur << endl;
      else
        cout << "Pas de Jules.";
    }

Discussions similaires

  1. Réponses: 7
    Dernier message: 11/03/2013, 10h15
  2. Réponses: 20
    Dernier message: 19/09/2012, 15h56
  3. insérer un petit formulaire sur le panel qui contient une image de fond
    Par amAtunisian dans le forum Interfaces Graphiques en Java
    Réponses: 1
    Dernier message: 08/06/2012, 13h28
  4. Réponses: 9
    Dernier message: 28/06/2011, 17h19
  5. Structure qui contient une chaine
    Par mayu5 dans le forum Débuter
    Réponses: 3
    Dernier message: 21/04/2008, 11h00

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