Taille et hauteur d'un arbre (2)

Différentes représentations

Cet exercice demande d'écrire les fonctions calculant la taille et hauteur d'un arbre. Il fait partie d'une série dans laquelle on utilise différentes représentations :

Dans tout le sujet, on considère des arbres enracinés. On rappelle que les arbres binaires ne sont pas des arbres enracinés.

On rappelle la définition d'un arbre enraciné : il s'agit d'une racine qui possède \(0\), \(1\) ou plusieurs sous-arbres qui sont eux-mêmes des arbres enracinés.

Un arbre enraciné qui ne possède pas de sous-arbre est appelé feuille.

On représente un arbre enraciné par une liste contenant la valeur portée par la racine suivie des sous-arbres. Une feuille est donc représentée par une liste d'un unique élément [x]x est une valeur quelconque.

L'arbre représenté par ["a", ["b"], ["c"], ["d", ["e"]]] a quant à lui une racine portant la valeur "a" et possède trois sous-arbres :

  • le premier est une feuille,

  • le deuxième est une feuille,

  • le troisième est un arbre qui a un sous-arbre qui est une feuille.

Cet arbre se dessine ainsi :

graph TD
    R{a} --> N1{b}
    R    --> N2{c}
    R    --> N3{d}
    N3   --> N4{e}

Dans cet exercice, la définition de la hauteur d'un arbre est le nombre maximal de filiations pour rejoindre la racine à une feuille. Un arbre réduit à sa racine a donc une hauteur égale à \(0\).

1. Taille de l'arbre

Écrire la fonction taille qui prend en paramètre une liste représentant un arbre et renvoie sa taille.

Exemples
>>> taille(["a"])
1
>>> taille(["a", ["b"], ["c"], ["d", ["e"]]])
5

###(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

.1280135[tf4)+2rR3,sao iug0àm1]PpnClh.e=cLéy:v(wq;S/b_dk050W0G0d0o0r0D0n0q0I0D0o0n0n0H010d0r0A010406050n0s0w0w0o0j0L040S0p0D0s0=0p0B0q020o0w0A0R0q0k0G0 0j0Q0s0G0n050T0|0~10120`0A041q1x051A0T1A1C1x0`0W0r0N0*0,0.0:0E0r0t0E0D1Q0E0d0^050#0U0D0G1L0-0/011P1R1T1R0d1Z1#1X0d0U0p0W121Y0j1y0d0E0*150n0A0o0B0:0i011%1N010e0%0G0B1d0G1X2224291)2c1#2f0w2h040a0q0z0j0p0A0p0n0r181a0Z200j0j0G0I2C1q2j0B1y0T1~2O0d1|1{1}0W2l0:1T0B2e2z1X1I1K0+1(2Y0r2!0B1^1J1X0A2H1y2M2O2_0{231a2*2a2/0j0 0D0^0x2L2}0_2|2k2 1)31330^0i3724392M2X013e0o34040l3i2N0`3l3c0:3o3q0f3t3k2}3m3z0^0b3C1z2@1q2(2R0W2V3m0I1^2r0Y1J1y2?0G2^383J3S0Z3!3b1M1)0X0^0Z0e3J3w3+0:0P0^0q3;3E3x3n0e0^0#0%1#3{3*2+010@040O442~3?3n0^100U2H4b3m480g0M3C060q4q3`3=460B403C4s3|4d0p0^0H4x3a4c460w0r354o4r4y452a3-040e0p0j4E4t300^0r4V4z460p3^042-4!4O3d0U0^0j240t0G4j3}484a1r3#4W1)4I4K4{3j4F4k0^0m4+4G304.042o4@4d4_5d4u4f0j4h4?512N534^0^0g4m4L4M4r5o4d4v040d573m4B044D5m044N583d4w5G5I5C0^0h5B3}5y410D435G5w465f5X4}3y5i5k5g2a480c5*5K4)5.0:480y0g5t4q5Y4P4/0!0s0j0B5R5x5L2_0`0T3%3Z3K690T3N1q0d3P6e2T2P1@1_2R0o1!6b3N1w3)5J0:2H0w0V0e0o0X0G0V0E0l0^1i1k1m1o0q4n5X1D391x0J0o0q4S0B2J0r193`683m1+1S1U1W6s3F5a1s3J673T5H2E0z0L1~6X0A0G320!0q0W003p0D0K4=0j0q1#202E6L1G3V2)4d6#1-1V2i4#2a2n2e2g0^2t0S0I0j0?0d2u6?0E193J3Y6s2`3#686)3}4Q3/5;014(3`5#7i3d3 5z0$5V5l2{5$470^4`7U7N5%044g4i7M4,5=5q6L654M5{3,5}0d5 615M7:0:4 04367_7V5D5Q7 7!3n6+0}7I5!7Z7*4e7Q427T4|84898g8b5y7%8f527V5,7I5y4Z7)6t7W045@62464Q4S4U838k4Y8z2a4%4Y7^2_5N5S5a4:0B4=887X7I7|7~8a8v48568E8v0B5a5c8u54498r5(7(8Y8,5r5^5G667D6a2O6q1B040C0!0d1$0o0A2?0p0I0E1$1o7t0o0s0.0r0q0N3p0r2E0W240)760I0-6}6 5j2H0)0j0K0W0s2B0)0v0q0s2!0q4:0I2-1$9q74056Z3}7e6%7h8k860w8T490c8y6M7D0q9b0q0K9i160K0q9D9O3T6!1U7f6(7`017|0u6-7D0F1z396c0!7R0n04.
2. Hauteur de l'arbre

Écrire la fonction hauteur qui prend en paramètre une liste représentant un arbre et renvoie sa hauteur.

Exemples
>>> hauteur(["a"])
0
>>> hauteur(["a", ["b"], ["c"], ["d", ["e"]]])
2

###(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

.1280135[tf4)+2rR3,sao iug0xm1]P6pOnl7he=céy:v(wq;S/b_dk050W0H0d0o0r0E0n0q0J0E0o0n0n0I010d0r0B010406050n0s0w0w0o0j0L040S0p0E0s0=0p0D0q020o0w0B0R0q0k0H0 0j0Q0s0H0n050T0|0~10120`0B041q1x051A0T1A1C1x0`0W0r0N0*0,0.0:0G0r0t0G0E1Q0G0d0^050#0U0E0H1L0-0/011P1R1T1R0d1Z1#1X0d0U0p0W121Y0j1y0d0G0*150n0B0o0D0:0i011%1N010e0%0H0D1d0H1X2224291)2c1#2f0w2h040a0q0z0j0p0B0p0n0r181a0Z200j0j0H0J2C1q2j0D1y0T1~2O0d1|1{1}0W2l0:1T0D2e2z1X1I1K0+1(2Y0r2!0D1^1J1X0B2H1y2M2O2_0{231a2*2a2/0j0 0E0^0x2L2}0_2|2k2 1)31330^0i3724392M2X013e0o34040l3i2N0`3l3c0:3o3q0f3t3k2}3m3z0^0b3C3v3E3x3n0p323p0^0A3J3a2~1M3d3O3f040F3C1z2@1q2(2R0W2V3m0J1^2r0Y1J1y2?0H2^383$3/0Z3`3b3W0:0X0^0Z0e3$3w41010P0^0q473L490D0e0^0G0o170H0s0j4e402+010@040O4q3V4s0D0^100U2H4x3m4u0g0M3J0q4L4d484s43040r461r384N4f4z0U0^2o4F3M4u4w4U3j3U3F4B0j4D0H4$494H3C4W4r2a0p0^0I0I4^4,3M0w0r354=4s4u4J4*3u4M5c4_4y2a4Q2H0d4o0D504O2a530^0u4K4M514g4j5m4X4{4}5x4`1)5p045r5a0_5c5u4P0^0e3O5B5f3d0^0r5P3m0p4b4R5l5H5e3F4Z040j240t4;5H5K2a4(565o5404365-5n1)4u0m5U3M0D5%4#5_5y5{0^4)2{5`3y4.4:5;65040g4I5s5d5#5 5w5!5.1)4|044 6n693n5%0 0v6d0:5:635C6a040G6z4t0^5}6t646E4k4m4o6H6B686M3n6b4E6C5Q6A0^0c6H4A4R6R0^0y6g6i6k495h0!5k5~495E5^2_6/4s6q0h6@4z6m2_0`0T3}3_3%770T3*1q0d3,7c2T2P1@1_2R0o1!793*1w3 6Z012H0w0V0e0o0X0H0V0G0l0^1i1k1m1o0q592{1D391x0C1a0B4n0d0q4l0.0r0q170%0r0n0H0j7X1a0t0K0D0K5)0d4n7%0o2c2D1$230j3/4o0r7%1#0)1I0e0e7-2e0d0)0n0p0s0n0V4C2H0)591G3=2)491+1S1U1W7q3m2n2e2g0^2t0S0J0j0?7S0z0L1~193$3^7q2`3{768p3M4Q456H5X4d6Y3F4i6F4l7/6Q8S4%666%6W5,6T6D6I6f7J38065J6u4Q4S7030612e6*4v8$048d8(3{6u4@6L8*6q4~8@5D5?6`916U586.8:6U6;5j0j5Z6{6o0:5E5G739g8*9i6?947r6_980:6~9z6v0^6x8{679c8*6(6O8X4p8Z4?8#9O718~4/6X8)7r4u6$9R305S8{6,9C4Q5N9N9m6u6(5T9w5V5X2-9C600^5)0D5+9G6H9y9!6e6K9-6U9_04629W4G9Qa96l9T6ca16!6f6-5H748K782O7o3)0!0$0(04.