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
.339.128013s3_8èufvy n7aS1me(P24C:twih)6o;bcdUg?/0làqp.rL-,=+Nk95Rxé050J0s0z0o0B0P0c0l0I0P0o0c0c0Y010z0B0S010406050c0h0r0r0o0U0k040p0F0P0h0~0F0m0l020o0r0S0G0l0(0s180U0R0h0s0c050N1517191b130S041z1G051J0N1J1L1G130J0B0j0?0^0`0|0C0B0L0C0P1Z0C0z11050.0H0P0s1U0_0{011Y1!1$1!0z1,1.1*0z0H0F0J1b1+0U1H0z0C0?1e0c0S0o0m0|0v011:1W010i0:0s0m1m0s1*2b2d2i1=2l1.2o0r2q040b0l0u0U0F0S0F0c0B1h1j0,290U0U0s0I2L1z2s0m1H0N272X0z2524260J2u0|1$0m2n2I1*1R1T0@1;2+0B2-0m211S1*0S2Q1H2V2X32142c1j2?2j2{0U180P110l0q2U3612352t381=3a3c3e0v3h2d3j2V2*013o0o3d040l0d3s2W133v3m0|3y3A0l0w3E3u363w3K3e0%3O3G3Q3I3x0F3b3z3e0E3V3k371V3n3!3p3B0n3)3H3,3J3.3$3B0f3=3X3@3Z3#3L0$3}3l3 3S040q0O443+2@403/0q3g1A3i3W454d470q3r4i3t4k4c393_3A0q3D4q3F3*3R4v110q3N4z3P4l4u414E3U4H4s4C4L483(4O4B3Y4n3;4U3?4m4D483|4Z3~4#4R0q434)4J3-4R0v4a4/4t4;3/0v4h324P4W4$0v4p4~4V46514y544!4K4{4G594*5b3`0v4N5e4:3^4=4T5k4_5m4{4Y5p4Q4{4(5u504=4.5y564R0d4@341M301z2;2!0J2(3w0I212A0+1S1H2 0s313i3O055Q0,5Y5l010#113m5!5a1=0A3e5.5f3n0I110!0F0s0h0J5?5)10040y4b3w5;3B0l69605q010c0J11016h653Y6e3e690l0x3,1/0B1n0P0*2z0m0.6x0l0h1j0m0a5~0l1R2b2I2d0z6G1/0d0l0o1{0U0B0H1g0=644^3w6l68690W0l0j3z5}0U0l0y0l0^6(6*0h6,2N0P000*0~1v0-0z0s0X6j3 6!6n0l6%0L0o0h0I0C1/6.1.0l0c0F0h0c0W190H2Q0l0Q0l787a7c0T724d746n6%0J2F2K7d6/1/7h7j7l0U7n1/7q7B0F7D7v4O4 736f6#6o1/0m001x6L2c0c0X0l0B0I0B7)2H6?6A1j7m7o0H2_0/2Q7)180B0=7/6,6B6P7K7o0J00192K0*0l0v7R5C7x7V756h013V75554d5+040,0i6b665=4H8m2j0i0r110e0e2_2K8B8s3Y620t8G3 0H620c0s0P8r8v5/0|62714H0l8w3n117s7b0s8K4d8V3O8Y8T3x116)1.6?8)2j8+8X8Z3J117O7D8@1=620D6X4~758l8.8M118O8Q900|0F118d5Z8.0m8#798%8,8{019f040Y9o9j9l7t8(4O966n9p99049b8R348.9r9h3t9p9k048;6+9u5@9e119t8`9v9O6=0U8k9A8-9S019D9F9d9q9g9,9N8~6 9R5)9r9V329%5)9:7C9=7S979(8o8q9,678Y8S9(0m0i117#0e0i5}0:1.9,8I9,9*8P9G9i9(92944j9$9{6c0c2g04011r0m0j7P1/82201e0*2n7)6:0U0*2H0m8O7p6-7F0l6D6F7#0W0:7;1/af0hah1/0M8j9z9$9p8o2Q0z6?0m9?6cam9ca89@9.a|6c9N8$7ca^3w0F677~b43Y0#5_045{2-b93 b6112d5 9W9(a`ao9L9Ia~9Ha98}9~9y9`9pbi04b8bm5)bb5`1ibx4j067T8n8}0sbp2W9pa69/ab040s0)5W0`0B1i0e2c2Q6x7c8ObIbqaq118Ja 3Racaj11939#6a8.8o0BbP3B9Mb?b;3Y9J9/ac0c0zaeag0Paic33 8Ib_a-9Aa/11a;a?bg4m0H9a2#b@04b:bt9|c2cw6cc5ce4m8:9Zct0Db`av3w8o8P8Octas4rauck04cm0Ua@bD6cakciau969p0c0q11000t00cIc#9Bbr040Zco39acbX2QbZb#b%2n271x0sb,bQ8.cZczb=bV9,cBd74W9w9ncC8^b^c.c/cJc411c?cXd8d35(cAbsapcx9Y8=9!c!dkdlbhdnc@8!bVc`1x2Jc}19c b*d2ctcvdvb0cydSb5dub-dw9;dr9p92djc/bzdEdp6kc)04000Dc-dAc:b.04cH4U0N5$5X1I5J0N5L1z0z5Ne32$2Y20222!0o1-d~e15U1Fds3w2Q0rae0o0#0s0e0C0d111r1t6}6W5!1M3j1G0p0B8Yd}d9d|5R3B7#a#0la%a)7)1i7g7i0C0/6 0lb(aD0k0s6,6:9P7:0c2d7 dMb)0g8O7)0J1i0I0leQeXaEeE5R3w1@1#1%1)ei4Wcq9Ecsdg91b/c6eGdcdD049Kd4budx9Qf78Udi8veH5%eL7b0/2-6M0?190o2S0gc{7R1P1K1c2_1ieP37e=6Q0gft0J0h0l6 0)eV0o0j2R6/002G0*0U6Q6+e{5%doeF6-1I3j0h0P3j1$040Kftc~e-aR7i0jf!6x0s7Rf;13f;0V7!dIc|1jf^270*0caJ6GfO7H7k7?7M7r9m7caT5#eIf b29yeF1zg105g3fX0SfZf#e(7i0=0i3.1/2NfQ6 g00Bf:gMg4bWbYdKg8e,gagcgHgfgD7J7LaSd!gneFf d!1zgt0Ngvf;f?1/g90Ce.a$e!18f~gL3j0Nf.g~0,0.0:0c04.