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 :

Question sur union-set


Sujet :

SL & STL C++

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Futur Membre du Club
    Profil pro
    Inscrit en
    Mars 2008
    Messages
    3
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mars 2008
    Messages : 3
    Par défaut Question sur union-set
    Bonjour, je suis etudiant en master informatique, et je travaille toujours (je vous avez deja contactez l'année derniere) sur un gros projet informatique necessitant l'utilisation de la STL mais avec de nombreuses contraintes sur la complexité.
    De ce fait, j'aimerais savoir si quelqu'un pouvait m'eclairer sur l'union ensembliste "union set" puisque j'ai besoin de cette operation pour faire l'union de deux "list" mais j'aimerais savoir comment cette fonction est implémentée, puisque j'ai pu remarquer que lorsque mes deux listes en entrée etaient triées le resultat (si j'utilise un back-inserter pour la liste en sortie) etait lui aussi trié (quels algorithmes se cachent derriere? serait-ce un tri par fusion ou autre chose?)
    De plus j'ai egalement remarquer en cherchant un peu moi meme que si j'entre des listes non triée alors l'union que j'obtiens en resultat n'est plus un union ensembliste mais la concatenation de mes deux listes en entrée.

    j'espere avoir etait le moins confus possible, merci d'avance.

  2. #2
    Expert éminent
    Avatar de koala01
    Homme Profil pro
    aucun
    Inscrit en
    Octobre 2004
    Messages
    11 644
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 53
    Localisation : Belgique

    Informations professionnelles :
    Activité : aucun

    Informations forums :
    Inscription : Octobre 2004
    Messages : 11 644
    Par défaut
    Salut, et bienvenue sur le forum.

    Pour ce que j'en sais, l'algorithme set_union utilise plutot la notion d'équivalence pour travailler.

    C'est à dire qu'il ne va pas utiliser l'égalité parfaite ( a == b ) mais bien partir du principe que "si a n'est pas plus petit que b, et que b n'est pas plus petit que a, c'est qu'ils sont équivalents".

    Cela peut justifier que, sur des conteneurs non triés, tu puisse obtenir des résultats "aberrants" correspondant à la concaténation des deux conteneurs fournis.

    La contrainte est donc claire pour utiliser ce type d'algorithme: il faut impérativement que les deux conteneurs soient triés

    Si, de manière générale, tu effectues plus de recherches que d'ajout dans ton conteneur, il peut en outre sembler opportun de te tourner vers un conteneur directement trié, tel que std::set ou std::map, mais là, il faut que tu réfléchisse à la situation réelle dans laquelle tu te trouve
    A méditer: La solution la plus simple est toujours la moins compliquée
    Ce qui se conçoit bien s'énonce clairement, et les mots pour le dire vous viennent aisément. Nicolas Boileau
    Compiler Gcc sous windows avec MinGW
    Coder efficacement en C++ : dans les bacs le 17 février 2014
    mon tout nouveau blog

Discussions similaires

  1. Question sur UNION et GROUP BY
    Par raicolin dans le forum MySQL
    Réponses: 2
    Dernier message: 15/12/2014, 12h30
  2. Question sur méthodes set/get
    Par tamerla dans le forum Débuter avec Java
    Réponses: 2
    Dernier message: 07/02/2014, 00h35
  3. question sur les "set/list"
    Par deubelte dans le forum C++
    Réponses: 12
    Dernier message: 29/12/2006, 01h16
  4. question sur les listes/set/vector
    Par deubelte dans le forum SL & STL
    Réponses: 16
    Dernier message: 28/12/2006, 20h17
  5. Question sur set::set
    Par socrate dans le forum C++
    Réponses: 5
    Dernier message: 07/09/2006, 18h22

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