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

avec Java Discussion :

Parcours d'un arbre avec java


Sujet :

avec Java

  1. #1
    Futur Membre du Club
    Homme Profil pro
    Étudiant
    Inscrit en
    Janvier 2012
    Messages
    4
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Canada

    Informations professionnelles :
    Activité : Étudiant
    Secteur : High Tech - Électronique et micro-électronique

    Informations forums :
    Inscription : Janvier 2012
    Messages : 4
    Par défaut Parcours d'un arbre avec java
    Bonjour et merci d'avance de votre aide!
    Je vous faire le parcours d'un arbre qui possède des numéros sur ses arcs.
    Si j'entre dans un noeud par le numéro 1, je dois le quitter par le numéro 2. Si un noeud possèdent 3 arcs numérotés de 0 à 2: si j'entre dans ce noeud par le numéro 2, je dois sortir par le numéro 0.

    Donc, je veux un programme java qui me permets de faire le parcours d'un arbre de cette manière. J'ai trouvé plusieurs programme qui font le parcours des arbres mais je n'ai pas trouvé la manière de faire en java cette méthode surtout que je n'ai que des notions de bases dans le langage.

    Voici une image pour vous aider à voir l'arbre!

    Merci -
    Images attachées Images attachées  

  2. #2
    Modérateur

    Avatar de Robin56
    Homme Profil pro
    Architecte de système d'information
    Inscrit en
    Juin 2009
    Messages
    5 297
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Ille et Vilaine (Bretagne)

    Informations professionnelles :
    Activité : Architecte de système d'information

    Informations forums :
    Inscription : Juin 2009
    Messages : 5 297
    Par défaut
    Citation Envoyé par Allouli2010 Voir le message
    Je vous faire le parcours d'un arbre qui possède des numéros sur ses arcs.
    Si j'entre dans un noeud par le numéro 1, je dois le quitter par le numéro 2. Si un noeud possèdent 3 arcs numérotés de 0 à 2: si j'entre dans ce noeud par le numéro 2, je dois sortir par le numéro 0.
    Euh comment peux tu entrer par un arc et sortir par l'autre si tu parcours un arbre ?

    Moi comme je vois un arbre la logique c'est :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    // Utilisation
    Noeud parent = arbre.getParent();
    parcoursArbre(parent);
    ...
     
    // Factorisation
    void parcoursArbre(Noeud parent) {
      System.out.println(parent.getName());
      for (Noeud fils : parent.getFils()) {
        parcoursArbre(fils);
      }
    }
    PS : Bon j'avoue que mon parcours là est en profondeur.
    Responsable Java de Developpez.com (Twitter et Facebook)
    Besoin d'un article/tutoriel/cours sur Java, consulter la page cours
    N'hésitez pas à consulter la FAQ Java et à poser vos questions sur les forums d'entraide Java
    --------
    Architecte Solution
    LinkedIn : https://www.linkedin.com/in/nicolascaudard/

  3. #3
    Futur Membre du Club
    Homme Profil pro
    Étudiant
    Inscrit en
    Janvier 2012
    Messages
    4
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Canada

    Informations professionnelles :
    Activité : Étudiant
    Secteur : High Tech - Électronique et micro-électronique

    Informations forums :
    Inscription : Janvier 2012
    Messages : 4
    Par défaut
    Merci de votre réponse!
    J'explique plus en détail dont j'ai besoin. SVP, regardez l'image pour mieux comprendre.
    Supposons que je suis sur le noeud "E", voici les étapes du parcours:
    je quitte "E" par 0 et j'entre dans "C" par 2
    je dois quitter "A" par 0 (parce que 2 est le plus grand nombre du noeuds)
    j'entre dans "A" par 1 et je dois le quitter par 0
    j'entre dans "B" par 1 et je dois le quitter par 0
    j'entre dans "D" par 0 et je le quitte par 0
    j'entre dans B par 0 et je dois le quitter par 1
    j'entre dans "A" par 0 et je dois le quitter par 1
    j'entre dans "c" par 1 et je dois le quitter par 1
    j'entre dans "F" par 0 et je le quitte par 0
    je reviens sur ma position initiale qui est "C" et vous remarquez que j'ai fait le parcours de tout l'arbre et je suis revenu à ma position initiale.

    je m'excuse si je n'étais pas clair dans ma question du début, mais c'est ce genre de parcours que je veux coder. S'il y a quelque chose qui n'est pas claire, SVP n'hésitez pas!

    Merci encore!
    Images attachées Images attachées  

  4. #4
    Modérateur

    Avatar de Robin56
    Homme Profil pro
    Architecte de système d'information
    Inscrit en
    Juin 2009
    Messages
    5 297
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Ille et Vilaine (Bretagne)

    Informations professionnelles :
    Activité : Architecte de système d'information

    Informations forums :
    Inscription : Juin 2009
    Messages : 5 297
    Par défaut
    Citation Envoyé par Allouli2010 Voir le message
    Supposons que je suis sur le noeud "E", voici les étapes du parcours:
    je quitte "E" par 0 et j'entre dans "C" par 2
    je dois quitter "A" par 0 (parce que 2 est le plus grand nombre du noeuds)
    j'entre dans "A" par 1 et je dois le quitter par 0
    j'entre dans "B" par 1 et je dois le quitter par 0
    j'entre dans "D" par 0 et je le quitte par 0
    j'entre dans B par 0 et je dois le quitter par 1
    j'entre dans "A" par 0 et je dois le quitter par 1
    j'entre dans "c" par 1 et je dois le quitter par 1
    j'entre dans "F" par 0 et je le quitte par 0
    je reviens sur ma position initiale qui est "C" et vous remarquez que j'ai fait le parcours de tout l'arbre et je suis revenu à ma position initiale.
    Ok eh bien dans ce cas il faut plus visualiser ton ensemble comme un graphe de point que comme un arbre. Tu auras ainsi des éléments "Noeud" avec des voisins "Noeud" avec un système de pondération entre chaque liaison.

    Pour ton parcours, il faut alors que tu vérifies les voisins de ton Noeud courant pour juger leur pondération puis réitérer l'opération au fur et à mesure. Ta condition d'arrêt étant alors de revenir au Noeud de départ.
    Responsable Java de Developpez.com (Twitter et Facebook)
    Besoin d'un article/tutoriel/cours sur Java, consulter la page cours
    N'hésitez pas à consulter la FAQ Java et à poser vos questions sur les forums d'entraide Java
    --------
    Architecte Solution
    LinkedIn : https://www.linkedin.com/in/nicolascaudard/

  5. #5
    Futur Membre du Club
    Homme Profil pro
    Étudiant
    Inscrit en
    Janvier 2012
    Messages
    4
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Canada

    Informations professionnelles :
    Activité : Étudiant
    Secteur : High Tech - Électronique et micro-électronique

    Informations forums :
    Inscription : Janvier 2012
    Messages : 4
    Par défaut
    Excuse moi, mais comment le faire en java?
    j'ai besoin d'un code même pour un arbre de 3 noeuds!
    je veux un exemple de code parce que je ne sais pas comment définir ces points ou pondérer les noeuds?!

    merci

  6. #6
    Expert éminent
    Avatar de tchize_
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Avril 2007
    Messages
    25 482
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 46
    Localisation : Belgique

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Avril 2007
    Messages : 25 482
    Par défaut
    Point:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    public class Point {
       private List<Arc> arcs
       public void relier(Arc lien) {....}
       public Point pointSuivant(int valeurEntree) {....}
    }
    Arc
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    public class Arc {
       private Point[] extremites;
       private int valeur;
       public Arc(Point... extremites){....}
       public Point getAutrePoint(Point premierPoint){.....}
       public int getValeur() {.....}
    }
    Plus qu'à mettre le code dedans pour gérer tout ton bousin

  7. #7
    Futur Membre du Club
    Homme Profil pro
    Étudiant
    Inscrit en
    Janvier 2012
    Messages
    4
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Canada

    Informations professionnelles :
    Activité : Étudiant
    Secteur : High Tech - Électronique et micro-électronique

    Informations forums :
    Inscription : Janvier 2012
    Messages : 4
    Par défaut
    Merci pour ta réponse!
    J'apprécies beaucoup.
    STP, peux-tu me faire un exemple pour 3 points et 2 arcs parce que j ne sais pas quoi écrire et qu'est ce que je devrais compléter.
    Merci de votre aide!

Discussions similaires

  1. Réponses: 3
    Dernier message: 16/05/2012, 23h36
  2. parcours en largeur d'un arbre avec file
    Par dede4 dans le forum Débuter
    Réponses: 2
    Dernier message: 19/12/2010, 20h59
  3. Arbre de décision avec Java
    Par medchok dans le forum Général Java
    Réponses: 1
    Dernier message: 14/04/2009, 12h28
  4. dessiner des arbres avec java
    Par manelisg dans le forum 2D
    Réponses: 13
    Dernier message: 09/04/2009, 16h29
  5. Parcours arbre avec les iterateurs
    Par Premium dans le forum Collection et Stream
    Réponses: 16
    Dernier message: 24/03/2006, 15h03

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