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

Python Discussion :

parcours préfixe en Python


Sujet :

Python

  1. #1
    Membre averti
    Homme Profil pro
    Étudiant
    Inscrit en
    Mars 2020
    Messages
    15
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 25
    Localisation : France, Loiret (Centre)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Mars 2020
    Messages : 15
    Par défaut parcours préfixe en Python
    Bonjour, je dois implémenter en Python le parcours préfixe d'un arbre représenté avec des dictionnaires te il doit retourner une liste avec les sommets et j'ai créé deux fonctions qui permettent d'extraire la partie gauche et droite d'un arbre mais le problème qu'à chaque fois il ne retourne pas le résultat.
    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
     
    def gauche(G,i):
        liste=[]
        for u in G:
            l=[]
            if i not in G:
                return 'None'
            else:
                for v in G[i]:
                    l.append(v)
                    liste=l[0]
        return liste
     
     
     
    def droite(G, i):
        liste = []
        for u in G:
            l = []
            if i not in G:
                return 'None'
            else:
                for v in G[i]:
                    liste = v[0]
     
        return liste
     
    def parcours(G,i):
        s = premierliste(G)
        nb=[]
        pere={}
        pere[s]=None
        for u in G:
            for v in G[u]:
                pere[v]=u
            while u != 'None':
                    nb.append(u) 
                    u=gauche(G,u)
                    print(u)
                    if u == 'None':
                        v=droite(G,pere[u])
                        nb.append(v) 
    return nb

  2. #2
    Membre confirmé
    Homme Profil pro
    Curieux
    Inscrit en
    Avril 2020
    Messages
    114
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 49
    Localisation : France, Seine et Marne (Île de France)

    Informations professionnelles :
    Activité : Curieux
    Secteur : Bâtiment

    Informations forums :
    Inscription : Avril 2020
    Messages : 114
    Par défaut
    Salut,
    pourquoi écrits tu
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    for v in G[i]:
                    l.append(v)
                    liste=l[0]
    Nous sommes d'accord que l comme liste sont deux listes, non?

  3. #3
    Membre averti
    Homme Profil pro
    Étudiant
    Inscrit en
    Mars 2020
    Messages
    15
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 25
    Localisation : France, Loiret (Centre)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Mars 2020
    Messages : 15
    Par défaut
    Pour obtenir juste le sommet qu'il me faut car j'ai besoin du sommet mais pas de la liste contenant le sommet pour ensuite l'utiliser dans l'algorithme du parcours.

  4. #4
    Membre confirmé
    Homme Profil pro
    Curieux
    Inscrit en
    Avril 2020
    Messages
    114
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 49
    Localisation : France, Seine et Marne (Île de France)

    Informations professionnelles :
    Activité : Curieux
    Secteur : Bâtiment

    Informations forums :
    Inscription : Avril 2020
    Messages : 114
    Par défaut
    est sensé ressembler à quoi ? Et je ne comprends pas la déclaration pour avoir
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    liste=l[0]
    et
    return liste
    et si à chacun de tes tests i n'est pas dans G ba que te dire, tu n'as pas un exemple complet avec G et i puis le résultat attendu ?

  5. #5
    Membre averti
    Homme Profil pro
    Étudiant
    Inscrit en
    Mars 2020
    Messages
    15
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 25
    Localisation : France, Loiret (Centre)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Mars 2020
    Messages : 15
    Par défaut
    par exemple:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
     
    G={'a':['b','c'], 'c':['f','e'], 'e':['d']}
     
    gauche(G,'a')
    gauche donnerait l'élément à gauche de la liste et pour ça, je retourne le sommet l[0], mais pour la fonction droite donnerait l' élément à droite de la liste si la longueur de la liste est supérieur à 1 et donc retourne le sommet l[1] mais je ne sais pas comment traiter la fonction si une clé a dans la liste plus de 2 éléments.

  6. #6
    Expert éminent
    Homme Profil pro
    Architecte technique retraité
    Inscrit en
    Juin 2008
    Messages
    21 715
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Manche (Basse Normandie)

    Informations professionnelles :
    Activité : Architecte technique retraité
    Secteur : Industrie

    Informations forums :
    Inscription : Juin 2008
    Messages : 21 715
    Par défaut
    Salut,

    Un parcours d'arbre en préfixe, c'est d'abord un algorithme, d'abord récursif (c'est plus simple). On pourrait écrire çà:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    def p(g, n):
        L = [ n ]
        if n in g:
            for c in g[n]:
                L += p(g, c)
        return L
     
     
    G={'a':['b','c'], 'c':['f','e'], 'e':['d']}
    print(p(G, 'a'))
    Après désolé mais je ne comprends pas pourquoi vous voulez avoir une gauche et une droite.

    Ça pourrait être utile pour transformer l'arbre en arbre binaire mais si c'est ce que vous voulez faire autant l'énoncer clairement....

    Et toujours pareil, c'est d'abord un algo. plutôt récursif qu'on peut coder avec Python (mais sans algo. vous pouvez toujours essayez ce que vous voulez, çà a peu de chance de marcher).
    note: côté algo. un peu de recherche sur Internet devrait vous donner des idées.

    - W
    Architectures post-modernes.
    Python sur DVP c'est aussi des FAQs, des cours et tutoriels

  7. #7
    Membre prolifique
    Avatar de Sve@r
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Février 2006
    Messages
    12 827
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Oise (Picardie)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : Aéronautique - Marine - Espace - Armement

    Informations forums :
    Inscription : Février 2006
    Messages : 12 827
    Billets dans le blog
    1
    Par défaut
    Bonjour
    Citation Envoyé par momo199 Voir le message
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
     
    G={'a':['b','c'], 'c':['f','e'], 'e':['d']}
     
    gauche(G,'a')
    gauche donnerait l'élément à gauche de la liste
    Donc "b" ???

    Citation Envoyé par momo199 Voir le message
    Citation Envoyé par momo199 Voir le message
    et j'ai créé deux fonctions qui permettent d'extraire la partie gauche et droite
    mais je ne sais pas comment traiter la fonction si une clé a dans la liste plus de 2 éléments.
    Ben si la clé a plus de 2 éléments, tu ne peux plus parler de partie gauche et droite !!!
    Mon Tutoriel sur la programmation «Python»
    Mon Tutoriel sur la programmation «Shell»
    Sinon il y en a pleins d'autres. N'oubliez pas non plus les différentes faq disponibles sur ce site
    Et on poste ses codes entre balises [code] et [/code]

  8. #8
    Membre Expert
    Homme Profil pro
    Inscrit en
    Octobre 2011
    Messages
    2 910
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Octobre 2011
    Messages : 2 910
    Par défaut
    Salut,

    Je crois que par "élément à gauche" il veut dire le premier élément de la liste et par "élément à droite" le dernier élément de la liste...

    Citation Envoyé par momo199 Voir le message
    ..., mais pour la fonction droite donnerait l' élément à droite de la liste si la longueur de la liste est supérieur à 1 et donc retourne le sommet l[1] mais je ne sais pas comment traiter la fonction si une clé a dans la liste plus de 2 éléments.
    Si par "élément à droite" tu veux dire le dernier élément de la liste alors tu peux y accéder en faisant : l[-1] quelque soit le nombre d'éléments de la liste l, ce qui est bien pratique...

Discussions similaires

  1. Python le parcours d'un arbre binaire en DFS correspond au préfixe ?
    Par lockmanz dans le forum Général Python
    Réponses: 2
    Dernier message: 10/12/2018, 20h13
  2. parcours préfixe d'un arbre en ocaml
    Par Nirolac dans le forum Caml
    Réponses: 1
    Dernier message: 11/12/2017, 00h12
  3. [Python 2.X] [python-constraints]ordre de parcours des variables
    Par fatbob dans le forum Bibliothèques tierces
    Réponses: 0
    Dernier message: 15/09/2014, 14h42
  4. Réponses: 7
    Dernier message: 15/04/2014, 19h44

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