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 :

Enregistrer un ABR


Sujet :

C

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre averti
    Profil pro
    Inscrit en
    Novembre 2009
    Messages
    47
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Novembre 2009
    Messages : 47
    Par défaut Enregistrer un ABR
    Bonjour,
    J'ai cherché sans succès la meilleure façon d'enregistrer un ABR (arbre binaire de recherche) dans un fichier binaire.

    Merci de votre aide.

    Ps: C'est un peu succinct mais je ne vois pas quoi ajouter...

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

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

    Informations forums :
    Inscription : Septembre 2005
    Messages : 27 393
    Par défaut
    ça dépend sous quelle forme tu espères le recharger.
    Si tu veux conserver la structure originelle de l'arbre, il te faudra stocker plus d'infos que si tu veux le recharger en tant que liste/tableau trié.
    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.

  3. #3
    Membre averti
    Profil pro
    Inscrit en
    Novembre 2009
    Messages
    47
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Novembre 2009
    Messages : 47
    Par défaut
    Citation Envoyé par Médinoc Voir le message
    ça dépend sous quelle forme tu espères le recharger.
    Si tu veux conserver la structure originelle de l'arbre, il te faudra stocker plus d'infos que si tu veux le recharger en tant que liste/tableau trié.
    Non, mon but est de recharger mon abr comme il était avant. Celui-ci contient un nom et une valeur (qui est la position du client vers un autre fichier).

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

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

    Informations forums :
    Inscription : Septembre 2005
    Messages : 27 393
    Par défaut
    Dans ce cas, je conseille un enregistrement récursif, et de la même manière que j'enregistrerais un arbre N-aire: Contenu du noeud, nombre d'enfants direct, enfants.

    Ce qui ferait:
    • En-tête du fichier: Nombre magique de 4 octets.
    • Pour chaque noeud:
      • Longueur du nom: 2 ou 4 octets.
      • Nom (sans caractère nul terminal, sans contraintes d'alignement)
      • Valeur
      • Nombre de fils: 2 ou 4 octets. Vaut zéro pour les feuilles.
      • Immédiatement suivi de son premier fils.


    Ainsi, un tel arbre:
    Code X : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
      D
     / \
     B E
    / \ \
    A C F
    Serait sauvegardé ainsi:
    (D, 2fils) (B, 2fils) (A, 0fils) (C, 0fils) (E, 1fils) (F, 0fils)

    Et pourra être lu de manière récursive, comme il a été sauvegardé.

    Edit: Note que quand un noeud n'a qu'un seul fils, il va falloir comparer pour savoir de quel côté il va. Peut-être un format spécial pour arbre binaires de recherche serait mieux (genre, avec une info qui indiquerait fils gauche ou fils droit)
    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.

  5. #5
    Membre averti
    Profil pro
    Inscrit en
    Novembre 2009
    Messages
    47
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Novembre 2009
    Messages : 47
    Par défaut
    Citation Envoyé par Médinoc Voir le message
    Dans ce cas, je conseille un enregistrement récursif, et de la même manière que j'enregistrerais un arbre N-aire: Contenu du noeud, nombre d'enfants direct, enfants.

    Ce qui ferait:
    • En-tête du fichier: Nombre magique de 4 octets.
    • Pour chaque noeud:
      • Longueur du nom: 2 ou 4 octets.
      • Nom (sans caractère nul terminal, sans contraintes d'alignement)
      • Valeur
      • Nombre de fils: 2 ou 4 octets. Vaut zéro pour les feuilles.
      • Immédiatement suivi de son premier fils.


    Ainsi, un tel arbre:
    Code X : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
      D
     / \
     B E
    / \ \
    A C F
    Serait sauvegardé ainsi:
    (D, 2fils) (B, 2fils) (A, 0fils) (C, 0fils) (E, 1fils) (F, 0fils)

    Et pourra être lu de manière récursive, comme il a été sauvegardé.

    Edit: Note que quand un noeud n'a qu'un seul fils, il va falloir comparer pour savoir de quel côté il va. Peut-être un format spécial pour arbre binaires de recherche serait mieux (genre, avec une info qui indiquerait fils gauche ou fils droit)
    Merci, je pense l'enregistrer comme cela:
    (D, 2fils, RAF) (B, 2fils, RAF) (A, 0fils, RAF) (C, 0fils,RAF) (E, 1fils, FisD) (F, 0fils, RAF)

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

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

    Informations forums :
    Inscription : Septembre 2005
    Messages : 27 393
    Par défaut
    C'est sans doute une bonne idée.
    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.

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

Discussions similaires

  1. Perte d'enregistrements
    Par AnnSo dans le forum Paradox
    Réponses: 15
    Dernier message: 06/08/2006, 23h39
  2. [VB6] [Crystal] Selection enregistrement
    Par littlecow dans le forum VB 6 et antérieur
    Réponses: 3
    Dernier message: 11/01/2005, 13h08
  3. Enregistrer un RichEdit dans un .Txt
    Par Clément[Delphi] dans le forum Composants VCL
    Réponses: 2
    Dernier message: 06/08/2002, 11h52
  4. [BDD] Enregistrer le résultat d'une requête
    Par Mowgly dans le forum C++Builder
    Réponses: 5
    Dernier message: 19/06/2002, 15h26
  5. enregistrer dans un fichier avec une appli mdi
    Par ferrari dans le forum C++Builder
    Réponses: 4
    Dernier message: 05/05/2002, 15h17

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