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 :

list (ou map?) dont le dernier élément "pointe" vers le premier


Sujet :

SL & STL C++

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Nouveau candidat au Club
    Inscrit en
    Novembre 2008
    Messages
    2
    Détails du profil
    Informations forums :
    Inscription : Novembre 2008
    Messages : 2
    Par défaut list (ou map?) dont le dernier élément "pointe" vers le premier
    Bonjour,

    je suis tout nouveau ici, j'ai regardé vite fait les sujets concernant les listes, et n'ai pas trouvé la réponse. J'essaie d'écrire un algorithme qui triangule des polygones. J'aimerais construire un container (contenant les sommets de la triangulation) dans lequel je pourrai insérer un nouvel élément (un nouveau sommet). A savoir: ces sommets sont repérés par un entier (le numéro du sommet) et possèdent deux coordonnées.
    Je pensais utiliser une slist (ou map, pour repérer le sommet avec une key entier) de la stl, mais un nouveau problème se pose. Quand je parcours la liste et que j'arrive au dernier élément, il faudrait que je puisse repasser au premier. Du style:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    slist<int> L;
    L.push_front(0);
    L.push_front(1); // L is "{1,0}".
     
    slist<int>::iterator it=L.begin(); //it pointe vers 1;
    it++; // it pointe maintenant sur 0;
    it++; // Là, j'aimerais que it pointe de nouveau sur 1, le premier élement.
    Merci d'avance

  2. #2
    Rédacteur/Modérateur
    Avatar de JolyLoic
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Août 2004
    Messages
    5 463
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 51
    Localisation : France, Yvelines (Île de France)

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Août 2004
    Messages : 5 463
    Ma session aux Microsoft TechDays 2013 : Développer en natif avec C++11.
    Celle des Microsoft TechDays 2014 : Bonnes pratiques pour apprivoiser le C++11 avec Visual C++
    Et celle des Microsoft TechDays 2015 : Visual C++ 2015 : voyage à la découverte d'un nouveau monde
    Je donne des formations au C++ en entreprise, n'hésitez pas à me contacter.

  3. #3
    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
    J'avais regardé et malheureusement l'iterateur n'est pas circulaire.

    Voici une solution :
    http://www.noveltheory.com/Iterators/Iterator_N0.htm

    Peut être qu'avec boost, comme le propose 3DArchi, y as plus simple....

  4. #4
    Rédacteur
    Avatar de 3DArchi
    Profil pro
    Inscrit en
    Juin 2008
    Messages
    7 634
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2008
    Messages : 7 634
    Par défaut
    Bonjour et bienvenu,
    De mémoire, je ne crois pas que cela existe tel quel - un itérateur 'circulaire' si j'ai bien compris. Je penses que c'est à toi de le gérer (boost.iterators peut t'aider pour faire tes itérateurs à partir d'autres itérateurs).
    Avec un tel itérateur, il te faudra être très vigilant sur les algos car un itérateur circulaire n'a, par définition, pas de fin.

  5. #5
    Nouveau candidat au Club
    Inscrit en
    Novembre 2008
    Messages
    2
    Détails du profil
    Informations forums :
    Inscription : Novembre 2008
    Messages : 2
    Par défaut
    Merci bien pour le lien vers boost.

    J'ai oublié d'ajouter que la taille de la liste circulaire que j'aimerais créer peut varier à chaque implémentation de l'iterator.

    Sinon je crée une sorte de map contenant le numéro du sommet, le numéro de celui qui suit (le numéro du sommet suivant le dernier serait donc le numéro du premier), et je m'arrange à la parcourir comme cela, mais je pense que ça prendra beaucoup de temps.

Discussions similaires

  1. Réponses: 2
    Dernier message: 22/04/2008, 16h21
  2. Dernier élément d'une liste
    Par nabil148911 dans le forum SQL
    Réponses: 1
    Dernier message: 03/08/2007, 12h26
  3. Réponses: 3
    Dernier message: 25/10/2006, 19h08

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