CONNEXION
  • RetourJeux
    • Sorties
    • Hit Parade
    • Les + populaires
    • Les + attendus
    • Soluces
    • Tous les Jeux
    • Gaming
  • RetourActu Gaming
    • News
    • Astuces
    • Tests
    • Previews
    • Toute l'actu gaming
  • RetourBons plans
    • Bons plans
    • Bons plans Smartphone
    • Bons plans Hardware
    • Bons plans Image et Son
    • Bons plans Amazon
    • Bons plans Cdiscount
    • Bons plans Decathlon
    • Bons plans Fnac
    • Tous les Bons plans
  • RetourJVTech
    • Actus High-Tech
    • Intelligence Artificielle
    • Smartphones
    • Mobilité urbaine
    • Hardware
    • Image et son
    • Tutoriels
    • Tests produits High-Tech
    • Guides d'achat High-Tech
    • JVTech
  • RetourCulture
    • Actus Culture
    • Culture
  • RetourVidéos
    • A la une
    • Gaming Live
    • Vidéos Tests
    • Vidéos Previews
    • Gameplay
    • Trailers
    • Chroniques
    • Replay Web TV
    • Toutes les vidéos
  • RetourForums
    • Hardware PC
    • PS5
    • Switch 2
    • Xbox Series
    • Switch
    • Pokemon pocket
    • FC 25 Ultimate Team
    • League of Legends
    • Tous les Forums
  • PC
  • PS5
  • Xbox Series
  • Switch 2
  • PS4
  • One
  • Switch
  • iOS
  • Android
  • MMO
  • RPG
  • FPS
En ce moment Genshin Impact Valhalla Breath of the wild Animal Crossing GTA 5 Red dead 2
Liste des sujets

[Aide] ArbreBinaire et python

Porte-a-Porte
Porte-a-Porte
Niveau 9
08 juin 2016 à 19:28:20

Bonsoir messieurs dames,
j'ai grandement besoin d'aide car ce code python que j'ai implenté moi-même de fonctionne pas, il est pourtant simple je pense:


class ArbreBinaire:

    def __init__(self,val,fd,fg):
        self.val = val
        self.fd = fd
        self.fg = fg
        self.hauteur = 1

    def estVide(self):
        if self is None:
            return True
        return False

    def prefixe(self): #rgd
        if not self.estVide():
            print(self.val)
            prefixe(self.fg)
            prefixe(self.fd)

    def infixe(self): #grd
        if not self.estVide():
            infixe(self.fg)
            print(self.value)
            infixe(self.fd)

    def suffixe(self): #gdr
        if not self.estVide():
            suffixe(self.fg)
            suffixe(self.fd)
            print(self.val)

    def inserer(self,val):
        if (self.estVide()):
            return ArbreBinaire(val,None,None)
        if(val < self.val):
                self.fg = self.fg.inserer(val)
        elif (val > self.val):
                self.fd = self.fd.inserer(val)

if __name__ == "__main__":
    a1 = ArbreBinaire(5,None,None)
    print(a1.estVide())
    a1.inserer(8)
    a1.inserer(2)
    a1.inserer(4)
    a1.prefixe()
    a1.suffixe()
    a1.infixe()

l'IDLE python m'affiche ceci :

False
Traceback (most recent call last):
File "/home/kevin/Bureau/tests /arbrebinaire.py", line 51, in <module>
a1.inserer(8)
File "/home/kevin/Bureau/tests /arbrebinaire.py", line 46, in inserer
self.fd = self.fd.inserer(val)
AttributeError: 'NoneType' object has no attribute 'inserer'

Pouvez-vous me venir en aide ? :svp:

Message édité le 08 juin 2016 à 19:29:33 par Porte-a-Porte
Porte-a-Porte
Porte-a-Porte
Niveau 9
08 juin 2016 à 22:38:20

Le 08 juin 2016 à 20:55:55 [Mc]zaoie a écrit :
Tu ne peux pas utiliser estVide(). Il va falloir utiliser une fonction qui te dis si ton arbre a un fils gauche et une fonction qui te dis si ton arbre a un fils droit.

<code>def inserer(self,val2):

if self.val < val2:
if self.fd is None:
self.fd = ArbreBinaire(val2, None, None)
else:
self.fd = self.fd.inserer(val2)
else:
if self.fg is None:
self.fg = ArbreBinaire(val2, None, None)
else:
self.fg = self.fg.inserer(val2)</code>

De manière brut sans faire ces fonctions.
C'est parce que ton None n'est pas typé et tu ne peux pas le forcer à être de type ArbreBinaire je pense.

Ok nickel, du coup je me suis dit que c'était le même soucis pour mes prefixe, suffixe et infixe, j'ai un autre soucis aussi, il me dit :

Prefixe :
5
Traceback (most recent call last):
File "/home/kevin/Bureau/tests /arbrebinaire.py", line 104, in <module>
a1.prefixe()
File "/home/kevin/Bureau/tests /arbrebinaire.py", line 67, in prefixe
prefixe(self.fg)
NameError: name 'prefixe' is not defined

Sous forums
  • Aide à l'achat Mac
  • Macintosh
  • Création de sites web
  • Création de Jeux
  • Linux
  • Programmation
  • Internet
  • Steam Deck
  • Hardware
La vidéo du moment