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 :

parcours particulier d'un set


Sujet :

SL & STL C++

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre éclairé Avatar de befalimpertinent
    Profil pro
    Inscrit en
    Avril 2007
    Messages
    561
    Détails du profil
    Informations personnelles :
    Âge : 41
    Localisation : France, Gironde (Aquitaine)

    Informations forums :
    Inscription : Avril 2007
    Messages : 561
    Par défaut parcours particulier d'un set


    Je souhaite itérer d'une manière un peu spécial sur un set. Pour des raisons que je ne n'expliquerai pas je dois absolument parcourir deux fois ma boucle si le set ne possède qu'un élément et tout le set sinon.

    J'ai codé ceci qui marche :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
     
    set<int> container;
    /*...*/
     
    set<int>::const_iterator it;
    int container_sz=container.size();
    const int nb_tours=container_sz==1 ? 2 :container_sz;
    int i;
    for(it=container.begin(),i=0;it!=container.end() || i<nb_tours;++it,++i)
       {
           if(container_sz<=1) it=container.begin();
       /*..*/
       }
    Mais je me demandais s'il existait une technique disons plus propre (je n'aime pas trop le if dans la boucle) de procéder.

    Toute idée est la bienvenue!
    Merci

  2. #2
    Membre émérite

    Profil pro
    Inscrit en
    Septembre 2006
    Messages
    717
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Septembre 2006
    Messages : 717
    Par défaut
    Les sous-fonctions sont tes amies
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    parcourirLeContainer(container);
    if (container.size() == 1)
      parcourirLeContainer(container);

  3. #3
    Membre éclairé Avatar de befalimpertinent
    Profil pro
    Inscrit en
    Avril 2007
    Messages
    561
    Détails du profil
    Informations personnelles :
    Âge : 41
    Localisation : France, Gironde (Aquitaine)

    Informations forums :
    Inscription : Avril 2007
    Messages : 561
    Par défaut
    Mouais sauf que ce que j'estime que ce que je met dans ma boucle n'a rien à faire dans une méthode puisque le code en question (dsl de ne pouvoir être plus précis) ne sera appelé qu'à cet endroit.

    Intéressant tout de même.
    what else

  4. #4
    Membre confirmé
    Inscrit en
    Octobre 2007
    Messages
    204
    Détails du profil
    Informations forums :
    Inscription : Octobre 2007
    Messages : 204
    Par défaut
    remplace ParcourirleContainer par ta boucle

  5. #5
    Membre éclairé Avatar de befalimpertinent
    Profil pro
    Inscrit en
    Avril 2007
    Messages
    561
    Détails du profil
    Informations personnelles :
    Âge : 41
    Localisation : France, Gironde (Aquitaine)

    Informations forums :
    Inscription : Avril 2007
    Messages : 561
    Par défaut
    Citation Envoyé par bachir006 Voir le message
    remplace ParcourirleContainer par ta boucle
    Dupliquer du code Pouaaa
    C'est pas ce que j'appelle coder proprement.

  6. #6
    Membre Expert

    Profil pro
    Inscrit en
    Juin 2006
    Messages
    1 294
    Détails du profil
    Informations personnelles :
    Localisation : Royaume-Uni

    Informations forums :
    Inscription : Juin 2006
    Messages : 1 294
    Par défaut
    Salut,

    Citation Envoyé par befalimpertinent Voir le message
    Mouais sauf que ce que j'estime que ce que je met dans ma boucle n'a rien à faire dans une méthode
    Mets-le dans une fonction locale, dans un namespace anonyme :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    namespace
    {
        void update( const std::set<int>& container )
        {
        }
    }
    edit : ou sinon tu peux aussi factoriser le traitement sur un élément plutôt que toute la boucle (puisqu'après tout tu n'as pas besoin de faire une boucle quand il n'y a qu'un seul élément)

    MAT.

  7. #7
    Alp
    Alp est déconnecté
    Expert confirmé

    Avatar de Alp
    Homme Profil pro
    Inscrit en
    Juin 2005
    Messages
    8 575
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 36
    Localisation : France, Bouches du Rhône (Provence Alpes Côte d'Azur)

    Informations forums :
    Inscription : Juin 2005
    Messages : 8 575
    Par défaut
    Citation Envoyé par Mat007 Voir le message
    Mets-le dans une fonction locale, dans un namespace anonyme :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    namespace
    {
        void update( const std::set<int>& container )
        {
        }
    }
    C'est cette solution que j'utiliserais pour ma part.

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

Discussions similaires

  1. Parcours particulier d'un tableau en Java ?
    Par noraix dans le forum Collection et Stream
    Réponses: 14
    Dernier message: 21/07/2011, 10h15
  2. executeQuery dans le parcours d'un result set ?
    Par xxkirastarothxx dans le forum JDBC
    Réponses: 0
    Dernier message: 14/04/2010, 16h57
  3. Problème assez particulier avec Set
    Par LiioR dans le forum Hibernate
    Réponses: 3
    Dernier message: 18/01/2009, 21h12
  4. Réponses: 2
    Dernier message: 05/12/2007, 22h16
  5. rapidité de parcours d'un set
    Par GLSpirit dans le forum SL & STL
    Réponses: 8
    Dernier message: 18/05/2007, 20h03

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