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

Ada Discussion :

Affichage Arbre N-aire sur terminal avec caractères "|" et "+--"


Sujet :

Ada

  1. #1
    Nouveau membre du Club
    Profil pro
    Inscrit en
    Novembre 2003
    Messages
    60
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Novembre 2003
    Messages : 60
    Points : 36
    Points
    36
    Par défaut
    Je suis actuellement sur un projet ADA utilisant les arbres n-aires. Pour le moment, j'arrive à afficher sur le terminal l'arbre test de cette façon :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    1
    11
    10
    9
    8
    7
    6 
    5
    4
    3
    2
    13
    12
    où 11 est le premier fils de 1, 10 9 8 7 sont les frères de 11, 6 est le premier fils 7, 5 est le premier fils de 6, 4 3 2 sont les frères de 5 et 13 12 sont les frères de 1.

    ceci est réalisé avec le code suivant via une procedure An_Afficher qui appelle une fonction auxiliaire An_Afficher_Aux qui est récursive :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
     
    -------------------------------------------------------------------
    ---- procedure An_Afficher : affiche le contenu complet de l'arbre
    ---- paramètres: arbre n-aire a
    ---- post-conditions: si l'arbre est vide, on leve l'exception arbre_vide 
    -------------------------------------------------------------------
     
    procedure An_Afficher( a: in arb_nr ) is
     
    begin
     
    if An_Vide(a) then
    raise arbre_vide;
    else
    An_Afficher_Aux(a,"");
    end if;
     
     
    end An_Afficher;
     
    ---------------------------------------------------------------------
    ---- procedure An_Afficher_aux : procédure récursive qui affiche les
    ---- valeurs de tous les fils et tous les freres.
    ---- parametres: arbre n-aire a
    ------------------------------------------------------------------
     
    procedure An_Afficher_Aux( a: in arb_nr ; str_decal: in string ) is
     
    begin
     
    if a=null then
    null;
    else
    put(str_decal);
    -- ecrire la valeur courante
    ecrire(a.val);
    -- on affiche le fils
    An_Afficher_Aux(a.premier_fils,str_decal&" ");
    -- on affiche le frere
    An_Afficher_Aux(a.frere,str_decal);
    end if; 
     
    end An_Afficher_Aux;
    avec la fonction ecrire qui est :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    procedure ecrire( a: in integer) is
     
    begin
     
    put(a);
    new_line;
     
    end ecrire_int;


    Maintenant, j'aimerais afficher l'arbre en y ajoutant les caractères "|" et "+--" pour mieux voir la filiation; ça donnerait pour l'arbre test :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    1
    |
    +--11
    | 10
    | 9
    | 8
    | 7
    | |
    | +--6 
    | |
    | +--5 
    | 4
    | 3
    | 2
    13
    12
    Malheureusement, je n'y arrive pas, un peu perdu dans la récursivité. J'ai essayé avec la procédure suivante :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    procedure An_Afficher_Aux( a: in arb_nr ; str_decal: in string ) is
     
    begin
     
    if a=null then
    null;
    else 
    put(str_decal);
    ecrire(a.val);
     
    if (not An_Vide(a.premier_fils)) then
    put(str_decal&"| "); 
    put(str_decal&"+--"); 
    end if;
    -- on affiche le fils
    An_Afficher_Aux(a.premier_fils,str_decal&" ");
    -- on affiche le frere
    An_Afficher_Aux(a.frere,str_decal);
    end if; 
     
    end An_Afficher_Aux;
    et avec An_Vide qui teste si un arbre est vide.

    mais ça ne me donne pas le résultat attendu :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
     
     
    1
    | +-- 11
    10
    9
    8
    7
    | +-- 6
    | +-- 5
    4
    3
    2
    13
    12
    Au passage, impossible aussi de coller la première valeur à gauche du terminal (la valeur 1), comment fait-on pour forcer le put au début de la ligne ?

    Si quelqu'un pouvait m'aider pour cet affichage, ça serait sympa !

  2. #2
    Invité
    Invité(e)
    Par défaut
    Bonjour,

    Pour aller en début de ligne c'est normalement le caractère 13, soit character'val(13) ou Latin_1.cr.
    Je vais regarder un peu mieux ton code et je reviens si j'ai mieux.

  3. #3
    Membre actif

    Homme Profil pro
    Mathématicien et développeur
    Inscrit en
    Mars 2012
    Messages
    132
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Suisse

    Informations professionnelles :
    Activité : Mathématicien et développeur
    Secteur : Finance

    Informations forums :
    Inscription : Mars 2012
    Messages : 132
    Points : 241
    Points
    241
    Billets dans le blog
    3
    Par défaut Put (integer) sans formattage
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    procedure ecrire( a: in integer) is
     
    begin
     
    put(a);
    new_line;
     
    end ecrire_int;
    Essaie Put(a,0) pour enlever les blancs qui sont placés avant le nombre.
    Les paramètres optionnels de Put sont visibles ici.

Discussions similaires

  1. Réponses: 0
    Dernier message: 16/04/2013, 11h07
  2. Affichage arbre n-aires
    Par pafi76 dans le forum Langage
    Réponses: 2
    Dernier message: 09/10/2008, 14h13
  3. arbre n-aire sur c#
    Par Aranjuez dans le forum C#
    Réponses: 1
    Dernier message: 16/05/2007, 15h56

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