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
| std::vector<std::string> Tgrammaire::suivants(std::string const &A){
std::map<std::string,std::vector<std::string>> dicoContenant;
std::vector<std::string> listeTete,groupe,pile,suiv,temp;
std::string T;
dicoContenant=creerDicoContenant(A,listeTete);//listeTetes en alias,
//initialisé ici
for(auto tete:listeTete)
for(auto prod:dicoContenant[tete])
if(prod.back()==A)
...
std::map<std::string,std::vector<std::string>> Tgrammaire::creerDicoContenant(std::string const &A,std::vector<std::string> &listeTetes){
std::map<std::string,std::vector<std::string>> ret;
for(auto tete:nonTerms) //nonTerms est le vector des têtes de production
for(auto prod:grammaire[tete]) //grammaire[tete] (grammaire est un dictionnaire comme dicoContenant) est
//l'ensemble des productions dont la tête est la valeur du string tete
if( ! absent(A,prod) && tete!=prod.back()){
ret.insert(std::pair<std::string,
std::vector<std::string>>(tete,prod));
listeTetes.push_back(tete);
}
return ret;
}
bool Tgrammaire::absent(std::string const &elem,
std::vector<std::string> const &liste){
int i;
bool ret;
for(i=0;i<liste.size() && elem!=liste[i];i++)
;
if(i==liste.size())
ret=true;//elem est absent
else
ret=false;
return ret;
}
ligne 9: error: no match for operator== (operand types are __gnu_cxx::__alloc_traits<std::allocator<char>, char>::value_type {aka char} and const string {aka const std::__cxx11::basic_string<char>})
195 | if(prod.back()==A && absent(tete,pile))
| ~~~~~~~~~~~^~~
| | |
| | const string {aka const std::__cxx11::basic_string<char>}
| __gnu_cxx::__alloc_traits<std::allocator<char>, char>::value_type {aka char} |
Partager