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

 C++ Discussion :

Exercice listes simplement chainées


Sujet :

C++

  1. #1
    Nouveau Candidat au Club
    Homme Profil pro
    Étudiant
    Inscrit en
    Novembre 2014
    Messages
    5
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 33
    Localisation : Algérie

    Informations professionnelles :
    Activité : Étudiant
    Secteur : Bâtiment

    Informations forums :
    Inscription : Novembre 2014
    Messages : 5
    Points : 0
    Points
    0
    Par défaut Exercice listes simplement chainées
    On souhaite gérer une population composee de plusieurs familles limitées à deux générations .
    Au premier niveau la liste est ordonnée par ordre alphabétique sur les noms de famille (liste simplement chainée de familles)
    une famille est un enregistrement avec un nom (chaine de 20 caractere) et un pointeur sur une liste de parents sachant que chaque parent possede une liste d'enfants (nombre illimité)
    chaque personne (parent ou enfant) est définie par un prénom (chaine de 20 caractere ) et un sexe

    TRAVAIL DEMANDE:
    ecrire un programme qui permet de:
    1: Ajouter:d'autres familles
    2: calculer : le nombre total d'enfants d'une famille donnée
    3: calculer: le nombre d'enfants d'un parent d'une famille donnée
    4: Afficher: les informations des parents d'une famille donnée ( prénom, sexe, nombre d'enfants pour chaque parent)
    5: supprimer: les enfants décédés d'un parent d'une famille donnée

    ENVIRONNEMENT DE DEVELOPPEMENT
    EN LANGAGE C++

  2. #2
    Invité
    Invité(e)
    Par défaut
    Bonjour à toi aussi, et bienvenue

    À noter qu'ici nous ne faisons pas les devoirs à ta place.
    Donc n'hésite pas à nous nous montrer ce que tu as déjà fait, et préciser ce qui te pose problème (niveau algorithme, syntaxe, erreurs de compilation...), et nous serons ravis de t'aider.

  3. #3
    Membre chevronné Avatar de Ehonn
    Homme Profil pro
    Étudiant
    Inscrit en
    Février 2012
    Messages
    788
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 34
    Localisation : France

    Informations professionnelles :
    Activité : Étudiant
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Février 2012
    Messages : 788
    Points : 2 160
    Points
    2 160
    Par défaut
    Bonjour et bienvenue.

    Au passage, il y a des "incohérences" entre l'exercice et les possibilités de C++.

    Citation Envoyé par PRENOMNOM Voir le message
    Au premier niveau la liste est ordonnée par ordre alphabétique sur les noms de famille (liste simplement chainée de familles)
    Pourquoi ne pas utiliser std::set ?

    Citation Envoyé par PRENOMNOM Voir le message
    une famille est un enregistrement avec un nom (chaine de 20 caractere) [...] chaque personne (parent ou enfant) est définie par un prénom (chaine de 20 caractere ) et un sexe
    Pourquoi limiter à 20 caractères et ne pas pas utiliser std::string ?

    Citation Envoyé par PRENOMNOM Voir le message
    et un pointeur sur une liste de parents sachant que chaque parent possede une liste d'enfants (nombre illimité)
    Je n'ai jamais été fan des conceptions qui proposent de pointer / référencer des "éléments" extérieur à la classe (cela complique souvent le programme). Mais la solution que je "préfère" dans ce cas est d'avoir le conteneur et les indices qui vont bien (si possible).
    Vu la tournure de l'énoncé, on pourrait penser à utiliser des itérateurs mais le problème de la l'invalidation de ces derniers est passé sous silence.

  4. #4
    Nouveau Candidat au Club
    Homme Profil pro
    Étudiant
    Inscrit en
    Novembre 2014
    Messages
    5
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 33
    Localisation : Algérie

    Informations professionnelles :
    Activité : Étudiant
    Secteur : Bâtiment

    Informations forums :
    Inscription : Novembre 2014
    Messages : 5
    Points : 0
    Points
    0
    Par défaut
    non ce n'est pas un devoir c est un exercice pour la comprendre bien de
    la manipulation des liste chaine et pour preparer au examen et merci

  5. #5
    Expert éminent sénior
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Février 2005
    Messages
    5 073
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 52
    Localisation : France, Val de Marne (Île de France)

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : Conseil

    Informations forums :
    Inscription : Février 2005
    Messages : 5 073
    Points : 12 119
    Points
    12 119

  6. #6
    Nouveau Candidat au Club
    Homme Profil pro
    Étudiant
    Inscrit en
    Novembre 2014
    Messages
    5
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 33
    Localisation : Algérie

    Informations professionnelles :
    Activité : Étudiant
    Secteur : Bâtiment

    Informations forums :
    Inscription : Novembre 2014
    Messages : 5
    Points : 0
    Points
    0
    Par défaut HELP
    Comment faire le chainage de trois listes (famille, parents, enfants) ?

  7. #7
    Expert éminent sénior
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Février 2005
    Messages
    5 073
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 52
    Localisation : France, Val de Marne (Île de France)

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : Conseil

    Informations forums :
    Inscription : Février 2005
    Messages : 5 073
    Points : 12 119
    Points
    12 119
    Par défaut
    Dans la classe Famille, utilisez un champ de type std::list<Parent>.
    Dans la classe Parent, utilisez un champ de type std::list<Enfant>.

  8. #8
    Nouveau Candidat au Club
    Homme Profil pro
    Étudiant
    Inscrit en
    Novembre 2014
    Messages
    5
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 33
    Localisation : Algérie

    Informations professionnelles :
    Activité : Étudiant
    Secteur : Bâtiment

    Informations forums :
    Inscription : Novembre 2014
    Messages : 5
    Points : 0
    Points
    0
    Par défaut HELP
    LA NOTION : N'utilise pas les classe ; les listes c'est tous

  9. #9
    Expert éminent sénior
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Février 2005
    Messages
    5 073
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 52
    Localisation : France, Val de Marne (Île de France)

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : Conseil

    Informations forums :
    Inscription : Février 2005
    Messages : 5 073
    Points : 12 119
    Points
    12 119
    Par défaut
    Citation Envoyé par PRENOMNOM Voir le message
    LA NOTION : N'utilise pas les classe ; les listes c'est tous
    Heu, comment dire sans s'énerver ?

    UNE LISTE, C'EST UNE CLASSE.

  10. #10
    Expert éminent sénior
    Avatar de Médinoc
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Septembre 2005
    Messages
    27 369
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 40
    Localisation : France

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

    Informations forums :
    Inscription : Septembre 2005
    Messages : 27 369
    Points : 41 519
    Points
    41 519
    Par défaut
    Il est possible que la traduction en Français correct soit:
    L'exercice consiste à recoder une liste chaînée pour montrer que vous avez compris le principe et bien faire rentrer les complexités algorithmiques associées dans vos têtes: Vous ne pouvez donc pas utiliser les conteneurs de la STL pour cet exercice.
    SVP, pas de questions techniques par MP. Surtout si je ne vous ai jamais parlé avant.

    "Aw, come on, who would be so stupid as to insert a cast to make an error go away without actually fixing the error?"
    Apparently everyone.
    -- Raymond Chen.
    Traduction obligatoire: "Oh, voyons, qui serait assez stupide pour mettre un cast pour faire disparaitre un message d'erreur sans vraiment corriger l'erreur?" - Apparemment, tout le monde. -- Raymond Chen.

  11. #11
    Membre chevronné

    Homme Profil pro
    Développeur informatique
    Inscrit en
    Avril 2013
    Messages
    610
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : Finance

    Informations forums :
    Inscription : Avril 2013
    Messages : 610
    Points : 1 878
    Points
    1 878
    Billets dans le blog
    21
    Par défaut
    Au premier niveau la liste est ordonnée par ordre alphabétique sur les noms de famille (liste simplement chainée de familles)
    une famille est un enregistrement avec un nom (chaine de 20 caractere) et un pointeur sur une liste de parents sachant que chaque parent possede une liste d'enfants (nombre illimité)
    chaque personne (parent ou enfant) est définie par un prénom (chaine de 20 caractere ) et un sexe
    Tu as donc besoin au minimum de deux types d'enregistrement:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    struct Personne {
      char prenom[20] ;
      int sexe;
      Personne* enfants;
      Personne* next;
    };
     
    struct Famille {
      char nom[20];
      Personne* parents;
      Famille* next;
    };
    1: Ajouter:d'autres familles
    comme il faut le faire dans l'ordre alphabétique tu devras écrire une fonction avec la signature suivante:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    void ajouterFamille(Famille* f, Famille* listeFamille);
    où listeFamille est la première famille de la liste et qui parcourra la liste jusqu'à trouver un nom postérieur dans l'ordre alphabétique.

    2: calculer : le nombre total d'enfants d'une famille donnée
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    unsigned nombreEnfants(Famille* listeFamille);
    3: calculer: le nombre d'enfants d'un parent d'une famille donnée
    4: Afficher: les informations des parents d'une famille donnée ( prénom, sexe, nombre d'enfants pour chaque parent)
    5: supprimer: les enfants décédés d'un parent d'une famille donnée
    etc...

    Les points importants sont les suivants:
    - une liste simplement chaînée est une liste dont les membres comporte d'une part une valeur, d'autre part un pointeur vers le prochain membre de la liste (ou nullptr s'il n'y en a pas). A noter que std::list est une liste doublement chaînée (chaque membre contient également un pointeur sur le membre précédent).
    - on parcourt une liste simplement chaînée avec une boucle du genre:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    for (Membre* m = debutListe; m != nullptr; m = m->next) {faireqqc(m);}
    - on insère un nouveau membre après le membre m de la façon suivante:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    Membre* tmp = m->next;
    m->next = nouveauMembre;
    nouveauMembre->next = tmp;
    - on supprime un membre m1 entre m0 et m2 de la façon suivante:
    Avec ces infos, un peu de sueur et de bon sens tu n'auras pas de difficulté à faire ton exercice et à avoir ton exam!

  12. #12
    Nouveau Candidat au Club
    Homme Profil pro
    Étudiant
    Inscrit en
    Novembre 2014
    Messages
    5
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 33
    Localisation : Algérie

    Informations professionnelles :
    Activité : Étudiant
    Secteur : Bâtiment

    Informations forums :
    Inscription : Novembre 2014
    Messages : 5
    Points : 0
    Points
    0
    Par défaut Merci
    Merciii

Discussions similaires

  1. fusion de deux liste simplement chainée
    Par mdh12 dans le forum Débuter
    Réponses: 6
    Dernier message: 14/01/2010, 19h23
  2. Tri d'une pile avec liste simplement chainée
    Par thecabbages dans le forum C
    Réponses: 3
    Dernier message: 17/12/2009, 21h08
  3. question liste simplement chainée
    Par american dans le forum Débuter avec Java
    Réponses: 2
    Dernier message: 15/03/2009, 21h45
  4. Réponses: 3
    Dernier message: 25/10/2006, 19h08
  5. Liste simplement chainée
    Par sorry60 dans le forum C
    Réponses: 54
    Dernier message: 29/11/2005, 22h05

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