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 :

unordered_map avec quelque chose qui resemble à un indice


Sujet :

C++

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre éclairé

    Homme Profil pro
    développeur à la maison
    Inscrit en
    Septembre 2006
    Messages
    417
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Tarn et Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : développeur à la maison

    Informations forums :
    Inscription : Septembre 2006
    Messages : 417
    Billets dans le blog
    16
    Par défaut unordered_map avec quelque chose qui resemble à un indice
    Bonjour,

    comment fait-on pour accéder, par exemple, au troisième pair d'un unordered_multimap avec quelqque chose qui ressemblerai à un indice?
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    std::unordered_multimap< std::string , std::vector<std::string> >G;
    une idée?

  2. #2
    Modérateur

    Avatar de Bktero
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Juin 2009
    Messages
    4 493
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 38
    Localisation : France, Loire Atlantique (Pays de la Loire)

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

    Informations forums :
    Inscription : Juin 2009
    Messages : 4 493
    Billets dans le blog
    1
    Par défaut
    Bonjour

    Comment accéder au n-ième élément d'une collection dont les éléments ne sont pas numérotés ?

    Hum....

    C'est quoi le 3e élément si la map est "unordered" ?

  3. #3
    Membre éclairé

    Homme Profil pro
    développeur à la maison
    Inscrit en
    Septembre 2006
    Messages
    417
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Tarn et Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : développeur à la maison

    Informations forums :
    Inscription : Septembre 2006
    Messages : 417
    Billets dans le blog
    16
    Par défaut
    peut-être qu'il me faut autre chose qu'un unordered multimap.
    j'ai ces productions:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    S -> A a
    S -> b
    A -> A c
    A -> S d
    A-> epsilon
    je voudrais accéder d'une manière simple à l'une de ces productions, et/ou en ajouter une entre deux autres, ou bien encore en modifier une
    j'utilisais un vector, mais on m'a dit que je me compliquai le travail avec.
    une idée?

  4. #4
    Expert confirmé
    Homme Profil pro
    Ingénieur développement matériel électronique
    Inscrit en
    Décembre 2015
    Messages
    1 599
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 62
    Localisation : France, Bouches du Rhône (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Ingénieur développement matériel électronique
    Secteur : High Tech - Électronique et micro-électronique

    Informations forums :
    Inscription : Décembre 2015
    Messages : 1 599
    Par défaut
    Si l'ordre des productions doit être conservé, la unordered_multimap<> n'est pas utilisable. Comme l'a indiqué @Bktero les éléments ne sont pas à une position donnée. Dans une unordered_multimap<> :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    S -> A a
    S -> b
    A -> A c
    A -> S d
    A-> epsilon
    est la même chose que:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    A-> epsilon
    A -> A c
    A -> S d
    S -> b
    S -> A a
    .Si tu ajoutes un élément (par exemple avec insert()) il se mettra quelque part dans la unordered_multimap<>. Précise mieux ton besoin. Il semble qu'il te faut utiliser la collection qui conserve l'ordre donc c'est plutôt std::vector<>

  5. #5
    Membre éclairé

    Homme Profil pro
    développeur à la maison
    Inscrit en
    Septembre 2006
    Messages
    417
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Tarn et Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : développeur à la maison

    Informations forums :
    Inscription : Septembre 2006
    Messages : 417
    Billets dans le blog
    16
    Par défaut
    voici comment je m'y suis pris:
    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
    #ifndef GRAMMAIRE_HPP
    #define GRAMMAIRE_HPP
     
    class grammaire{
    public:
      std::vector<std::vector<std::string>>presencerecurs();
      int comptertete(std::string tete);
      int termine(std::string s);
      void parseur();
    private:
      std::vector<std::vector<std::string>>grammaire_s;
      std::string axiome;
      std::vector<std::string>terminaux;
      std::vector<std::string>nonterminaux;
      std::vector<std::vector<std::string>>listesnonrecurs;
    };
    #endif
    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
    59
    60
    61
    62
    63
    64
    65
    66
    67
    68
    69
    70
    71
    72
    73
    74
    75
    76
    77
    78
    79
    80
    81
    82
    83
    84
    85
    86
    87
    88
    89
    #include <iostream>
    #include <string>
    #include <vector>
    #include <algorithm>
    #include "grammaire.hpp"
     
    int main(){
      std::vector<std::vector<std::string>>listerecurs;
      grammaire G;
      G.parseur();
      listerecurs =G.presencerecurs();
      for(auto p:listerecurs){
        for(auto s:p)
          std::cout<<s<<' ';
        std::cout<<std::endl;
      }
      return 0;
    }
     
    void grammaire::parseur(){
      terminaux={"a","b","c","d","epsilon"};
      nonterminaux={"S","A"};
      grammaire_s={
        {"S","A","a"},     // S -> A a
        {"S","b"},           // S -> b
        {"A","A","c"},     // A -> A c
        {"A","S","d"},     // A -> S d
        {"A","epsilon"}   // A -> epsilon
      };
      axiome="S";
    }
     
     
    std::vector<std::vector<std::string>>
    grammaire::presencerecurs(){
      std::vector<std::vector<std::string>>temporaire,archive;
      std::vector<std::string> unelistenonrecurs;
      int n1,n2;
     
      n1=comptertete(axiome);
      for(int i=0;i<n1;i++){
        unelistenonrecurs.push_back(axiome);
        listesnonrecurs.push_back(unelistenonrecurs);
        unelistenonrecurs.clear();
      }
      for(auto p:grammaire_s){
        temporaire.clear();
        n2=termine(p[0]);//listenonrecursterminé par p[0]
        if(n2!=-1){
          unelistenonrecurs=listesnonrecurs[n2];
          if(std::find(nonterminaux.begin(),nonterminaux.end(),p[1])!=nonterminaux.end()){
    	if(std::find(unelistenonrecurs.begin(),unelistenonrecurs.end(),p[1])!=unelistenonrecurs.end()){
    	  while(unelistenonrecurs[0]!=p[1])
    	    unelistenonrecurs.erase(unelistenonrecurs.begin());
    	  archive.push_back(unelistenonrecurs);//recurs gauche détectée
    	  listesnonrecurs.erase(listesnonrecurs.begin()+n2);
    	  continue;
    	}
    	else{
    	  unelistenonrecurs.push_back(p[1]);
    	  n1=comptertete(p[1]);
    	  for(int i=0;i<n1;i++)
    	    temporaire.push_back(unelistenonrecurs);
    	  listesnonrecurs.erase(listesnonrecurs.begin()+n2);
    	  listesnonrecurs.insert(listesnonrecurs.end(),temporaire.begin(),temporaire.end());
    	}
          }
          else
    	listesnonrecurs.erase(listesnonrecurs.begin()+n2);
        }
      }
      return archive;
    }
     
    int grammaire::termine(std::string fin){
      //retourne l'indice de liste tel que 'fin' soit son dernier symbole
      for(size_t i=0;i<listesnonrecurs.size();i++)
        if(listesnonrecurs[i].back()==fin)
          return i;
      return -1;
    }
     
    int grammaire::comptertete(std::string s){
      int c=0;
      for(auto &p:grammaire_s)
        if(s==p[0])
          c++;
      return c;
    }

  6. #6
    Membre Expert
    Profil pro
    Inscrit en
    Juillet 2006
    Messages
    1 511
    Détails du profil
    Informations personnelles :
    Localisation : France, Paris (Île de France)

    Informations forums :
    Inscription : Juillet 2006
    Messages : 1 511
    Par défaut
    Salut,

    Ce que tu décrit me fait fortement penser aux collections VB6.
    C'est un conteneur qui associe une clef à une valeur.
    Les items sont insérés dans l'ordre.
    On peut accéder aux items par clef ou par indice.

    Tu peux te faire une classe qui ressemble à ceci:
    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
    #include <string>
    #include <vector>
    #include <utility>
     
    class Collection
    {
    private:
    	std::vector<std::pair<std::string, std::string>> mData;
    public:
    	std::string get(size_t) const;
    	std::string get(std::string const&);
    	void insert(std::pair<std::string, std::string> const&);
            void remove(size_t);
    	void remove(std::string const&);
            size_t size() const;
    };
     
    #include "Collection.h"
     
    std::string Collection::get(size_t index) const
    {
    	// retourne le 2e element (la valeur) de la paire à l'indice index
    }
     
    std::string Collection::get(std::string const& key)
    {
    	// recherche dans mData quel premier element (la clef) des pairs stockées correspond à key
    }
     
    void Collection::insert(std::pair<std::string, std::string> const&)
    {
    	// une insertion bête et mechante
    }
     
    void Collection::remove(size_t index)
    {
           // voir commentaire get(size_t index)
    }
     
    void Collection::remove(std::string const& key)
    {
           // voir commentaire get(std::string const& key)
    }
     
    size_t Collection::size() const
    {
    	return mData.size();
    }
    A toi de voir si tu veux des intérateur.

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

Discussions similaires

  1. Afficher quelque chose qui suive l'ascenseur
    Par Zebulon777 dans le forum Mise en page CSS
    Réponses: 7
    Dernier message: 28/01/2015, 08h17
  2. ToolTip ou quelque chose qui ressemble
    Par tifsa dans le forum Agents de placement/Fenêtres
    Réponses: 4
    Dernier message: 09/12/2014, 16h18
  3. unittest : tester quelque chose qui marche
    Par rambc dans le forum Général Python
    Réponses: 1
    Dernier message: 25/10/2010, 00h07
  4. quelque chose qui m'echappe avec le singleton.
    Par turican2 dans le forum Débuter avec Java
    Réponses: 12
    Dernier message: 17/06/2009, 15h13
  5. Réponses: 1
    Dernier message: 03/10/2008, 21h16

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