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
| #include <algorithm>
#include <set>
#include <map>
#include <string>
using namespace std;
char* ListeMots[] = { "Bonjour",
"Salut",
"Hello",
"Hi",
"Bonjour",
"Coucou",
"Hello" };
struct Remplir
{
Remplir( map<string, int> & tousLesMots,
set<string> & doublons )
: m_map( tousLesMots ),
m_set( doublons )
{
}
template <typename T>
void operator() ( T const & mot ) const
{
// Mot existant
if ( m_map.find( mot ) != m_map.end() )
m_set.insert( mot );
else
m_map[ mot ] = 'int '; // ou ce que tu veux
}
private:
map<string, int> & m_map;
set<string> & m_set;
};
struct Supprimer
{
Supprimer( map<string, int> & tousLesMots )
: m_map( tousLesMots )
{
}
template <typename T>
void operator() ( T const & mot ) const
{
m_map.erase( mot );
}
private:
map<string, int> & m_map;
};
int main()
{
map<string, int> motsUniques;
set<string> doublons;
// Ajoute tous les mots de la liste dans la map et trouve les doublons
for_each( ListeMots, ListeMots + sizeof(ListeMots)/sizeof(char**),
Remplir( motsUniques, doublons ) );
// Supprime de la map les doublons du set
for_each( doublons.begin(), doublons.end(),
Supprimer( motsUniques ) );
return 0;
} |
Partager