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 :

Comment créer un arbre binaire à partir d'une liste en Python ?


Sujet :

Python

  1. #1
    Nouveau Candidat au Club
    Homme Profil pro
    Étudiant
    Inscrit en
    Mars 2018
    Messages
    1
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 26
    Localisation : Cameroun

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Mars 2018
    Messages : 1
    Points : 1
    Points
    1
    Par défaut Comment créer un arbre binaire à partir d'une liste en Python ?
    Bonsoir !! Je cherche comment je peux prendre une liste et la transformer en arbre binaire ? Par exemple, si ma liste contient l'expression suivantes: (2+y)*(75-2), alors je cherche à avoir l'expression sous cette forme *,(+,(2),(y)),(-,(75),(2)) puis je cherche aussi à implémenter sur l'arbre les trois fonction de parcours (postfixe, infixe, préfixe), tout ceci en Python.
    Merci d'avance pour vos aides.

  2. #2
    Membre émérite

    Homme Profil pro
    Ingénieur calcul scientifique
    Inscrit en
    Mars 2013
    Messages
    1 229
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Alpes Maritimes (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Ingénieur calcul scientifique

    Informations forums :
    Inscription : Mars 2013
    Messages : 1 229
    Points : 2 328
    Points
    2 328
    Par défaut
    Bonsoir

    Il y a des librairies pour cela. sympy par exemple, mais il y en a plein d'autre.
    Si maintenant il s'agit d'un exo, alors vous pouvez vous inspirez de ce qui existe déjà, mais il faut commencer par présenter un bout de code pour qu'on vous aide dessus ...

  3. #3
    Expert éminent Avatar de BufferBob
    Profil pro
    responsable R&D vidage de truites
    Inscrit en
    Novembre 2010
    Messages
    3 035
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations professionnelles :
    Activité : responsable R&D vidage de truites

    Informations forums :
    Inscription : Novembre 2010
    Messages : 3 035
    Points : 8 400
    Points
    8 400
    Par défaut
    salut,

    Citation Envoyé par Providjek Voir le message
    (...) l'expression suivantes: (2+y)*(75-2) (...) sous cette forme : (*,(+,(2),(y)),(-,(75),(2))
    vu d'ici il est question de créer un parser, dans lequel il faudra définir une grammaire, tenir compte de la précédence des opérateurs etc.
    le module pyparsing permet de faciliter l'écriture d'un tel parser, il y a même un exemple qui correspond quasiment à ce que tu cherches ou est au moins un bon point de départ

  4. #4
    Membre habitué Avatar de racine carrée
    Homme Profil pro
    Étudiant
    Inscrit en
    Mars 2018
    Messages
    156
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 23
    Localisation : France, Maine et Loire (Pays de la Loire)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Mars 2018
    Messages : 156
    Points : 137
    Points
    137
    Par défaut
    Bonsoir,
    j'ai déjà du faire un exo comme ça une fois.
    Sans utiliser de module particulier, voilà comment je pense qu'il faudrait commencer:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    def div(exp):
        l=['']
        for k in exp:
            if k in '0123456789':
                l[-1]+=k
            else:
                l+=[k,'']
        return l
    Cette fonction décompose l'expression (chaine de caractères) en un liste; exemple:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    In [11]: div('39+(4*81-9)-72*9')
    Out[11]: ['39', '+', '', '(', '4', '*', '81', '-', '9', ')', '', '-', '72', '*', '9']
    Bon courage !

Discussions similaires

  1. Comment créer un layout xml à partir d'une customize view ?
    Par dév20 dans le forum Composants graphiques
    Réponses: 1
    Dernier message: 02/02/2014, 03h40
  2. Comment créer un fichier TEXT à partir d'une page HTML ?
    Par Zebulon777 dans le forum VBScript
    Réponses: 0
    Dernier message: 17/09/2010, 14h23
  3. Réponses: 0
    Dernier message: 15/04/2009, 17h52
  4. comment créer un array js à partir d'une requête PHP Mysql
    Par tavarlindar dans le forum Général JavaScript
    Réponses: 3
    Dernier message: 17/08/2008, 23h29
  5. Comment créer un document XML à partir d'une chaine de caractères
    Par imad_eddine dans le forum Format d'échange (XML, JSON...)
    Réponses: 2
    Dernier message: 19/11/2007, 18h09

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