Aller au contenu

Expression parenthésée⚓︎

Une expression arithmétique ne comportant que les quatre opérations \(+, - , ×, ÷\) peut être représentée sous forme d'arbre. La disposition des nœuds indique les priorités opératoires.

  • Les feuilles représentent des nombres, elles ne possèdent pas de sous-arbre.
  • Les nœuds internes représentent des opérateurs binaires, ils possèdent exactement deux sous arbres.

Par exemple, avec un parcours en profondeur infixe de l'arbre ci-dessous, on peut retrouver l'expression notée habituellement : \(((3 × (8 + 7)) - (2 + 1))\).

arbre

La classe Noeud ci-après met en œuvre une structure d'arbre adaptée.

Il ne s'agit pas exactement d'un arbre binaire

Avec un arbre binaire, tous les nœuds ont exactement deux sous-arbres. Un sous arbre peut alors être vide.

Ici, il s'agit d'un arbre d'expression pour opérateurs binaires. C'est un arbre d'arité 2 ; il n'y a pas, ici, de notion d'arbre vide. Ici, chaque nœud possède 0 ou 2 sous-arbre.

Compléter la fonction récursive expression_parenthesee qui prend en paramètre un objet de la classe Noeud qui désigne la racine d'un arbre et qui renvoie l'expression arithmétique représentée par l'arbre passé en paramètre, sous forme d'une chaine de caractères contenant des parenthèses.

Exemple

Résultat attendu avec l'arbre ci-dessus :

>>> somme_1 = Noeud(Noeud(None, 8, None), '+', Noeud(None, 7, None))
>>> somme_2 = Noeud(Noeud(None, 2, None), '+', Noeud(None, 1, None))
>>> produit_1 = Noeud(Noeud(None, 3, None), '*', somme_1)
>>> expression = Noeud(produit_1, '-', somme_2)
>>> expression_parenthesee(expression)
'((3*(8+7))-(2+1))'

D'autres exemples

>>> feuille = Noeud(None, 5, None)
>>> expression_parenthesee(feuille)
'5'
>>> somme = Noeud(Noeud(None, 2, None), '+', Noeud(None, 3, None))
>>> expression_parenthesee(somme)
'(2+3)'
>>> somme = Noeud(Noeud(None, 2, None), '+', Noeud(None, 3, None))
>>> produit = Noeud(Noeud(None, 4, None), '*', somme)
>>> expression_parenthesee(produit)
'(4*(2+3))'
###(Dés-)Active le code après la ligne # Tests (insensible à la casse)
(Ctrl+I)
Entrer ou sortir du mode "deux colonnes"
(Alt+: ; Ctrl pour inverser les colonnes)
Entrer ou sortir du mode "plein écran"
(Esc)
Tronquer ou non le feedback dans les terminaux (sortie standard & stacktrace / relancer le code pour appliquer)
Si activé, le texte copié dans le terminal est joint sur une seule ligne avant d'être copié dans le presse-papier
Évaluations restantes : 10/10
.128013.339snc)wuql3 (è;ébokp/h1t?à,aRPmy7f4UL_296ev-8x+dCiSg:5=N.0r050V0P0x0B0X0j0c0l0e0j0B0c0c0$010x0X0t010406050c0h0E0E0B0*0F040Y0r0j0h0~0r0d0l020B0E0t0o0l0C0P180*0i0h0P0c050u1517191b130t041z1G051J0u1J1L1G130V0X0Q0?0^0`0|0v0X0Z0v0j1Z0v0x11050.0q0j0P1U0_0{011Y1!1$1!0x1,1.1*0x0q0r0V1b1+0*1H0x0v0?1e0c0t0B0d0|0M011:1W010H0:0P0d1m0P1*2b2d2i1=2l1.2o0E2q040a0l0D0*0r0t0r0c0X1h1j0,290*0*0P0e2L1z2s0d1H0u272X0x2524260V2u0|1$0d2n2I1*1R1T0@1;2+0X2-0d211S1*0t2Q1H2V2X32142c1j2?2j2{0*180j110l0w2U3612352t381=3a3c3e0M3h2d3j2V2*013o0B3d040l0k3s2W133v3m0|3y3A0l0I3E3u363w3K3e0#3O3G3Q3I3x0r3b3z3e0O3V3k371V3n3!3p3B0G3)3H3,3J3.3$3B0S3=3X3@3Z3#3L0N3}3l3 3S040w0)443+2@403/0w3g1A3i3W454d470w3r4i3t4k4c393_3A0w3D4q3F3*3R4v110w3N4z3P4l4u414E3U4H4s4C4L483(4O4B3Y4n3;4U3?4m4D483|4Z3~4#4R0w434)4J3-4R0M4a4/4t4;3/0M4h324P4W4$0M4p4~4V46514y544!4K4{4G594*5b3`0M4N5e4:3^4=4T5k4_5m4{4Y5p4Q4{4(5u504=4.5y564R0k4@341M301z2;2!0V2(3w0e212A0+1S1H2 0P313i3O055Q0,5Y5l010s113m5!5a1=0g3e5.5f3n0e110%0r0P0h0V5?5)10040!4b3w5;3B0l69605q010c0V11016h653Y6e3e690l0W3,1/0X1n0j0p2z0d0.6x0l0h1j0d0b5~0l1R2b2I2d0x6G1/0k0l0B1{0*0X0q1g0=644^3w6l68690R0l0Q3z5}0*0l0!0l0^6(6*0h6,2N0j000p0~1v0-0x0P0A6j3 6!6n0l6%0Z0B0h0e0v1/6.1.0l0c0r0h0c0R190q2Q0l0z0l787a7c0(724d746n6%0V2F2K7d6/1/7h7j7l0*7n1/7q7B0r7D7v4O4 736f6#6o1/0d001x6L2c0c0A0l0X0e0X7)2H6?6A1j7m7o0q2_0/2Q7)180X0=7/6,6B6P7K7o0V00192K0p0l0M7R5C7x7V756h013V75554d5+040,0H6b665=4H8m2j0H0E110L0L2_2K8B8s3Y620m8G3 0q620c0P0j8r8v5/0|62714H0l8w3n117s7b0P8K4d8V3O8Y8T3x116)1.6?8)2j8+8X8Z3J117O7D8@1=620f6X4~758l8.8M118O8Q900|0r118d5Z8.0d8#798%8,8{019f040$9o9j9l7t8(4O966n9p99049b8R348.9r9h3t9p9k048;6+9u5@9e119t8`9v9O6=0*8k9A8-9S019D9F9d9q9g9,9N8~6 9R5)9r9V329%5)9:7C9=7S979(8o8q9,678Y8S9(0d0H117#0L0H5}0:1.9,8I9,9*8P9G9i9(92944j9$9{6c0c2g04011r0d0Q7P1/82201e0p2n7)6:0*0p2H0d8O7p6-7F0l6D6F7#0R0:7;1/af0hah1/0y8j9z9$9p8o2Q0x6?0d9?6cam9ca89@9.a|6c9N8$7ca^3w0r677~b43Y0s5_045{2-b93 b6112d5 9W9(a`ao9L9Ia~9Ha98}9~9y9`9pbi04b8bm5)bb5`1ibx4j067T8n8}0Pbp2W9pa69/ab040P0T5W0`0X1i0L2c2Q6x7c8ObIbqaq118Ja 3Racaj11939#6a8.8o0XbP3B9Mb?b;3Y9J9/ac0c0xaeag0jaic33 8Ib_a-9Aa/11a;a?bg4m0q9a2#b@04b:bt9|c2cw6cc5ce4m8:9Zct0fb`av3w8o8P8Octas4rauck04cm0*a@bD6cakciau969p0c0w11000m00cIc#9Bbr040Uco39acbX2QbZb#b%2n271x0Pb,bQ8.cZczb=bV9,cBd74W9w9ncC8^b^c.c/cJc411c?cXd8d35(cAbsapcx9Y8=9!c!dkdlbhdnc@8!bVc`1x2Jc}19c b*d2ctcvdvb0cydSb5dub-dw9;dr9p92djc/bzdEdp6kc)04000fc-dAc:b.04cH4U0u5$5X1I5J0u5L1z0x5Ne32$2Y20222!0B1-d~e15U1Fds3w2Q0Eae0B0s0P0L0v0k111r1t6}6W5!1M3j1G0Y0X8Yd}d9d|5R3B7#a#0la%a)7)1i7g7i0v0/6 0lb(aD0F0P6,6:9P7:0c2d7 dMb)0n8O7)0V1i0e0leQeXaEeE5R3w1@1#1%1)ei4Wcq9Ecsdg91b/c6eGdcdD049Kd4budx9Qf78Udi8veH5%eL7b0/2-6M0?190B2S0nc{7R1P1K1c2_1ieP37e=6Q0nft0V0h0l6 0TeV0B0Q2R6/002G0p0*6Q6+e{5%doeF6-1I3j0h0j3j1$040Jftc~e-aR7i0Qf!6x0P7Rf;13f;0K7!dIc|1jf^270p0caJ6GfO7H7k7?7M7r9m7caT5#eIf b29yeF1zg105g3fX0tfZf#e(7i0=0H3.1/2NfQ6 g00Xf:gMg4bWbYdKg8e,gagcgHgfgD7J7LaSd!gneFf d!1zgt0ugvf;f?1/g90ve.a$e!18f~gL3j0uf.g~0,0.0:0c04.