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

Java Discussion :

[Arbre] Remplir un arbre


Sujet :

Java

  1. #1
    Membre régulier
    Inscrit en
    Avril 2011
    Messages
    56
    Détails du profil
    Informations forums :
    Inscription : Avril 2011
    Messages : 56
    Points : 118
    Points
    118
    Par défaut [Arbre] Remplir un arbre
    Bonjour,

    J'aimerais remplir un arbre java de la facon suivante :

    Un texte de type :

    a b c d|e f g|h

    donnerais :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
     
                     a
                     |
                     b
                     |
                     c
                   /   \
                  d     e
                  |     |
                  f     f
                 / \   / \
               g  h  g   h
    Pour le moment j'ai fait l'algo suivant :

    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
     
     
        ArrayList<String> patterns;
        ArrayList<Node> nodes;
        Node root;
        int deep = 0;
        private String pattern[];
     
        public void build() {
    	nodes = new ArrayList<Node>();
    	for (int i=0; i<patterns.size(); i++) {
    	    pattern = patterns.get(i).split(" ");
    	    root = createNode();
    	    nodes.add(root);
    	}
        }
     
        public Node createNode() {
    	Node tmp = new Node();
     
    	if (deep < pattern.length) {
    	    deep++;
    	    for (int i=0; i<pattern.length; i++) {
    				Node node = new Node();
    				node.setValue(pattern[deep-1]);
    				node.addChild(createNode());
    				tmp = node;
    			}
    			deep--;
    		}
    		return tmp;
        }
        }
    J'arrive donc a cree un arbre normal sans probleme avec mon algo recursif. Mais J'arrive pas a gerer le pipe. Je sais pas si je vais dans la bonne voie.

    Une petite idee ?

  2. #2
    Modérateur
    Avatar de kolodz
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Avril 2008
    Messages
    2 211
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 36
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : High Tech - Produits et services télécom et Internet

    Informations forums :
    Inscription : Avril 2008
    Messages : 2 211
    Points : 8 316
    Points
    8 316
    Billets dans le blog
    52
    Par défaut
    Donc ton algo doit ressemblé à cela :

    1. Découper ton String en bloque correspondant aux niveaux de l'arbre.
    "a b c|d" => { "a", "b", "c|d"}
    2. Découper un niveau en ses nodes constituant
    "a" => {"a"}
    "c|d"=> {"c","d"}
    3. Crée les nodes du niveaux courant dans chaque node du niveau précédent.

    Je te propose d'avoir 3 méthodes de base :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    public String[] splitTreeToLevels(String tree);
    public String[] splitLevelToNodes(Strong level);
    public List<Node> creetNodes(String[] nodes, List<Node> parents);
    // retourne la liste des Nodes crée => on vise la récusivité

    L'algo général aurai donc la tête suivante :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    	public List<Node> buildTree(String pattern) {
    		List<Node> previousLevel = new ArrayList<Node>();
    		Node root = new Node("root");
    		previousLevel.add(root);
    		String levels = splitTreeToLevels(pattern);
    		for (String level : levels) {
    			String nodes = splitLevelToNodes(level);
    			previousLevel = creetNodes(nodes, previousLevel);
    		}
    		return root;
    	}
    Cordialement,
    Patrick Kolodziejczyk
    Si une réponse vous a été utile pensez à
    Si vous avez eu la réponse à votre question, marquez votre discussion
    Pensez aux FAQs et aux tutoriels et cours.

  3. #3
    Membre régulier
    Inscrit en
    Avril 2011
    Messages
    56
    Détails du profil
    Informations forums :
    Inscription : Avril 2011
    Messages : 56
    Points : 118
    Points
    118
    Par défaut
    ok super merci, je test tout de suite

Discussions similaires

  1. Remplir un arbre binaire avec une table ordonnée.
    Par Invité dans le forum Algorithmes et structures de données
    Réponses: 1
    Dernier message: 26/11/2009, 16h20
  2. Réponses: 2
    Dernier message: 25/06/2007, 11h07
  3. Réponses: 6
    Dernier message: 12/04/2007, 20h30
  4. remplir un arbre xml
    Par ecdxml dans le forum Format d'échange (XML, JSON...)
    Réponses: 2
    Dernier message: 03/07/2006, 10h47
  5. [Arbre] Construire un arbre
    Par ludovic.fernandez dans le forum Algorithmes et structures de données
    Réponses: 7
    Dernier message: 16/05/2006, 13h40

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