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
| #include <algorithm>
#include <sstream>
#include <set>
#include <map>
#include <string>
#include <fstream>
using namespace std;
// Foncteur qui, à partir d'une ligne, remplit la map et le set
// Formatage supposé de la ligne : "mot;123"
struct Remplir
{
Remplir( map<string, int> & tousLesMots,
set<string> & doublons )
: m_map( tousLesMots ),
m_set( doublons )
{
}
template <typename T>
void operator() ( T const & constligne ) const
{
string ligne( constligne );
istringstream iss( ligne );
string mot;
getline( iss, mot, ';' );
int i;
iss >> i;
// Mot existant
if ( m_map.find( mot ) != m_map.end() )
m_set.insert( mot );
else
m_map[ mot ] = i;
}
private:
map<string, int> & m_map;
set<string> & m_set;
};
// Foncteur qui supprime un mot d'une map
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()
{
ifstream file( "C:\\test.txt" );
map<string, int> motsUniques;
set<string> doublons;
// Ajoute tous les mots de la liste dans la map et trouve les doublons
for_each( istream_iterator<string>(file), istream_iterator<string>(),
Remplir( motsUniques, doublons ) );
// Supprime de la map les doublons du set
for_each( doublons.begin(), doublons.end(),
Supprimer( motsUniques ) );
return 0;
} |
Partager