Soyez le premier à donner votre avis sur cette source.
Snippet vu 9 223 fois - Téléchargée 20 fois
int removeDoublon(vector<string> & liste) { int cpt=0; bool bFound=false; vector<string> final; vector<string>::iterator iterListe, iterFinal; // Test de la validité de la liste if (liste.empty()) return cpt; // Init de la liste résultat final.push_back(*liste.begin()); for (iterListe=liste.begin()+1; iterListe!=liste.end(); iterListe++) { // Recherche si ce n'est pas un doublon bFound=false; for (iterFinal=final.begin(); iterFinal!=final.end() && !bFound; iterFinal++) { if (0==iterListe->compare(*iterFinal)) { // C'est un doublon, on passe à la chaîne suivante cpt++; bFound=true; } } if (!bFound) { // Ce n'est pas un doublon, on l'ajoute à la liste finale final.push_back(*iterListe); } } liste=final; return cpt; }
vector<string>::iterator iter; vector<string> liste; liste.push_back("coucou"); liste.push_back("couCou"); liste.push_back("SALUT"); liste.push_back("sAlut"); liste.push_back("coucouuu"); liste.push_back(""); liste.push_back("coucou"); liste.push_back("coucou"); liste.push_back("SALUT"); liste.push_back("SALUTE"); for (iter=liste.begin(); iter!=liste.end(); iter++) cout << *iter << " "; cout << endl; int cpt=removeDoublon(liste); cout << cpt << " doublons enleves: "; for (iter=liste.begin(); iter!=liste.end(); iter++) cout << *iter << " "; cout << endl;
Modifié par cptpingu le 30/07/2013 à 12:36
1) Soit on utilise sort + erase + unique:
2) Soit on converti le std::vector en std::set, puis on recopie le std::set dans le std::vector (on peut aussi choisir de conserver le std::set plutôt que de repasser au std::vector)
Méthode 1) plus rapide s'il y a peu de doublons.
Méthode 2) plus rapide s'il y a beaucoup de doublons.
Pour avoir le nombre de doublons enlevés, il suffit de comparer la taille avant et après.
Vous n'êtes pas encore membre ?
inscrivez-vous, c'est gratuit et ça prend moins d'une minute !
Les membres obtiennent plus de réponses que les utilisateurs anonymes.
Le fait d'être membre vous permet d'avoir un suivi détaillé de vos demandes et codes sources.
Le fait d'être membre vous permet d'avoir des options supplémentaires.