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

SL & STL C++ Discussion :

Compter le nombre de valeurs unqiues


Sujet :

SL & STL C++

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre éclairé
    Inscrit en
    Avril 2005
    Messages
    1 110
    Détails du profil
    Informations forums :
    Inscription : Avril 2005
    Messages : 1 110
    Par défaut Compter le nombre de valeurs unqiues
    Je cherche à compter un nombre de valeurs uniques (les données d'origine sont dans un tableau de tableaux, 2 std::vector<> imbriqués quoi).

    Je me propose très simplement de créer un std::set<> en parcourant mon tableau puis en lire la taille.

    Y-a-t-il mieux, plus performant ? Par exemple, créer un std::vector<>, le trier, puis compter les valeurs uniques.

    Merci !

  2. #2
    r0d
    r0d est déconnecté
    Membre expérimenté

    Homme Profil pro
    Développeur informatique
    Inscrit en
    Août 2004
    Messages
    4 290
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Ain (Rhône Alpes)

    Informations professionnelles :
    Activité : Développeur informatique

    Informations forums :
    Inscription : Août 2004
    Messages : 4 290
    Billets dans le blog
    2
    Par défaut
    Bonjour,

    Que veux-tu dire par "valeur unique" ?
    Sinon, tu peux jeter un coup d'oeil du côté de la fonction std::unique (en-tête <algorithm>, cf. lien dans ma signature).

  3. #3
    Membre éclairé
    Inscrit en
    Avril 2005
    Messages
    1 110
    Détails du profil
    Informations forums :
    Inscription : Avril 2005
    Messages : 1 110
    Par défaut
    5, 2, 3, 5, 4, 2, 4, 7, 1

    Distinctes si tu préfères. Dans cet exemple il y a 6 valeurs distinctes parmi un total de 9.

    std::unique(), je vais regarder.
    Ceci dit, l'usage de std::set<> est une solution comme je le disais, mais est-ce "bien" ?

  4. #4
    Membre éclairé
    Inscrit en
    Avril 2005
    Messages
    1 110
    Détails du profil
    Informations forums :
    Inscription : Avril 2005
    Messages : 1 110
    Par défaut
    Je viens de voir std::unique(). Il en fait trop dans mon cas, j'ai juste besoin de les compter. La modification éventuel ajoute en complexité inutile.
    Mais c'est une fonction intéressante à retenir (sauf que conserver le tri, indispensable avant l'appel de la fonction, n'eut pas été surperflu en sortie).

    PS:
    Dans ta documentation sur <algorithm> (très intéressante d'ailleurs) tu ne parles pas des fonctions "heap". Un petit tuto à leur sujet serait pas mal

  5. #5
    yan
    yan est déconnecté
    Rédacteur
    Avatar de yan
    Homme Profil pro
    Ingénieur expert
    Inscrit en
    Mars 2004
    Messages
    10 035
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 43
    Localisation : France, Ille et Vilaine (Bretagne)

    Informations professionnelles :
    Activité : Ingénieur expert
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Mars 2004
    Messages : 10 035
    Par défaut
    Salut,
    tu pourrai te faire un foncteur pour cela.



    Code C++ : 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
     
    #include <algorithm>
    #include <iostream>
    #include <vector>  
     #include <set>  
     
    template <class T>
    struct CombienUnique
    	{
    	CombienUnique(){};
    	//constructeur par recopie bidon qui eviter de recopier le set.
    	//swap les contenu des set
    	CombienUnique(CombienUnique<T> & CU)
    		{
    		std::swap(myUnique,CU.myUnique);
    		}
    	void operator()(const T & t) {myUnique.insert(t);}
    	int GetNbUnique() {return myUnique.size();};
     
    	std::set<T> myUnique;
    };
     
    int main(int argc, char** argv)
    {
    //initialisation
    std::vector<int> myvect;
    myvect.push_back(1);
    myvect.push_back(4);
    myvect.push_back(10);
    myvect.push_back(1);
    myvect.push_back(20);
    myvect.push_back(1);
    myvect.push_back(10);
     
    //récupère les uniques
    CombienUnique<int> myFoncteur = std::for_each(myvect.begin(),myvect.end(),CombienUnique<int>());
    //affichage
    std::cout<<"Nb unique : "<<myFoncteur.GetNbUnique()<<std::endl;
    std::copy(myFoncteur.myUnique.begin(),myFoncteur.myUnique.end(),std::ostream_iterator<int> (std::cout,"\n"));
     
    return 0;
    }

  6. #6
    Membre éclairé
    Inscrit en
    Avril 2005
    Messages
    1 110
    Détails du profil
    Informations forums :
    Inscription : Avril 2005
    Messages : 1 110
    Par défaut
    j'en suis


    Bon, en attendant d'approfondir <algorithm> je vais me contenter d'un plus classique
    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
    int main(int argc, char** argv)
    {
    //initialisation
    std::vector<int> myvect;
    myvect.push_back(1);
    myvect.push_back(4);
    myvect.push_back(10);
    myvect.push_back(1);
    myvect.push_back(20);
    myvect.push_back(1);
    myvect.push_back(10);
     
    //récupère les uniques
    std::set<int> s;
    {
    for (std::vector<int>::iterator it=myvect.begin();it!=myvect.end();it++)
    	s.insert(*it);
    }
    //affichage
    cout<< "Nb unique : " << s.size() << endl;
    {
    for (std::set<int>::iterator it=s.begin();it!=s.end();it++)
    	cout << *it << endl;
    }
     
    return 0;
    }

  7. #7
    yan
    yan est déconnecté
    Rédacteur
    Avatar de yan
    Homme Profil pro
    Ingénieur expert
    Inscrit en
    Mars 2004
    Messages
    10 035
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 43
    Localisation : France, Ille et Vilaine (Bretagne)

    Informations professionnelles :
    Activité : Ingénieur expert
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Mars 2004
    Messages : 10 035
    Par défaut
    Citation Envoyé par camboui Voir le message
    j'en suis


    Bon, en attendant d'approfondir <algorithm> je vais me contenter d'un plus classique
    Au moins tu as compris mon code

  8. #8
    yan
    yan est déconnecté
    Rédacteur
    Avatar de yan
    Homme Profil pro
    Ingénieur expert
    Inscrit en
    Mars 2004
    Messages
    10 035
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 43
    Localisation : France, Ille et Vilaine (Bretagne)

    Informations professionnelles :
    Activité : Ingénieur expert
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Mars 2004
    Messages : 10 035
    Par défaut
    EN faite, le foncteur n'est pas tellement necessaire ici. C'est vrai
    mais bon je m'entraine

    tu as beaucoup plus rapide pour initialiser ton set :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    std::set<int> s(myvect.begin(),myvect.end());

    ou

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    std::set<int> s
    .
    .
    .
    s.clear();
    s.insert(myvect.begin(),myvect.end());

  9. #9
    Membre Expert
    Avatar de poukill
    Profil pro
    Inscrit en
    Février 2006
    Messages
    2 155
    Détails du profil
    Informations personnelles :
    Âge : 41
    Localisation : France

    Informations forums :
    Inscription : Février 2006
    Messages : 2 155
    Par défaut
    Je vois que tu t'éclates avec les foncteurs MonGaulois !

    Effectivement, un petit:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    std::set<int> s(myvect.begin(),myvect.end());
    std::cout << s.size() << std::endl;
    permet de compter les uniques...
    Ce ne sera pas l'algo le plus rapide, mais au moins ça marche bien ! :-)

  10. #10
    yan
    yan est déconnecté
    Rédacteur
    Avatar de yan
    Homme Profil pro
    Ingénieur expert
    Inscrit en
    Mars 2004
    Messages
    10 035
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 43
    Localisation : France, Ille et Vilaine (Bretagne)

    Informations professionnelles :
    Activité : Ingénieur expert
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Mars 2004
    Messages : 10 035
    Par défaut
    Citation Envoyé par poukill Voir le message
    Je vois que tu t'éclates avec les foncteurs MonGaulois !

    Effectivement, un petit:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    std::set<int> s(myvect.begin(),myvect.end());
    std::cout << s.size() << std::endl;
    permet de compter les uniques...
    Ce ne sera pas l'algo le plus rapide, mais au moins ça marche bien ! :-)
    ben, en y réfléchissant je ne voit pas comment faire plus rapide....

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

Discussions similaires

  1. Comment compter le nombre de valeur différentes
    Par chelmi95 dans le forum IHM
    Réponses: 3
    Dernier message: 02/05/2008, 18h02
  2. [TCD]Compter le nombre de valeurs distinctes
    Par xaramelaz dans le forum Excel
    Réponses: 2
    Dernier message: 16/08/2007, 20h37
  3. Compter le nombre de valeur en rouge
    Par marsupilami34 dans le forum Macros et VBA Excel
    Réponses: 3
    Dernier message: 25/05/2007, 14h18
  4. Compter le nombre de valeurs différentes
    Par solorac dans le forum Excel
    Réponses: 6
    Dernier message: 21/04/2007, 16h13
  5. [Excel] Compter le nombre de valeurs
    Par Malach dans le forum Excel
    Réponses: 3
    Dernier message: 06/04/2006, 00h04

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