Chiffres romains (1)

Le but de cet exercice est d’écrire une fonction récursive traduire_romain qui prend en paramètre une chaîne de caractères, non vide, représentant un nombre écrit en chiffres romains et qui renvoie son écriture décimale.

Les chiffres romains considérés sont : I, V, X, L, C, D et M. Ils représentent respectivement les nombres 1, 5, 10, 50, 100, 500, et 1000 en base dix.

On dispose d’un dictionnaire romains dont les clés sont les caractères apparaissant dans l’écriture en chiffres romains et les valeurs sont les nombres entiers associés en écriture décimale :

romains = {"I":1, "V":5, "X":10, "L":50, "C":100, "D":500, "M":1000}

Le code de la fonction traduire_romain fournie repose sur le principe suivant :

  • la valeur d’un caractère est ajoutĂ©e Ă  la valeur du reste de la chaĂ®ne si ce caractère a une valeur supĂ©rieure (ou Ă©gale) Ă  celle du caractère qui le suit ;

  • la valeur d’un caractère est retranchĂ©e Ă  la valeur du reste de la chaĂ®ne si ce caractère a une valeur strictement infĂ©rieure Ă  celle du caractère qui le suit.

Ainsi, XIV correspond au nombre 10 + 5 - 1 puisque :

  • la valeur de X (10) est supĂ©rieure Ă  celle de I (1), on ajoute donc 10 Ă  la valeur du reste de la chaĂ®ne, c’est-Ă -dire IV ;

  • la valeur de I (1) est strictement infĂ©rieure Ă  celle de V (5), on soustrait donc 1 Ă  la valeur du reste de la chaĂ®ne, c’est-Ă -dire V.

Compléter le code fourni dans l'IDE et le tester

###(Dés-)Active le code après la ligne # Tests (insensible à la casse)
(Ctrl+I)
Entrer ou sortir du mode "deux colonnes"
(Ctrl+Clic pour inverser les colonnes)
Entrer ou sortir du mode "plein Ă©cran"
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 : 5/5

.8217.1280130ldy14-]ké/weibmc_:35qaPr+ 7=9o[fgt28;6sSRh)(punv050e0o0K0y0p0d0P0C0s0d0y0P0P0E010K0p0V010406050P0W0r0r0y0A0f040Q0G0d0W0?0G0X050m0}0 11130{0V04051j1c1m0m1j0{0e0p0Y0+0-0/0;0S0p0J0S0d1A0S0K0_050$0q0d0o1v0.0:011z1B1D1B0K1J1L1H0K0A1k0K0S0+160P0V0y0X0;0L011N1x010I0(0o0X0y0r0o1H1*1,1;1P1@1L1`1|0_0b0C0z0A0G0V0G0P0p190X0C0!1(0A0A0o0s2h1c1 0X1k0m1$2u1Z1#1!1I0e210;1D0X1_2e1H1s1u0,1O2E0p2G0X0G2K1H0V2n1k2s2u2Y0|1+2i2M1=2R0A100d0_0g2r2$0`2#202(1P2*2,0_0L2:1,2=2s2D012`0y2-040v2~2t0{312^0;34360h39302$323f0_0w3i3b3k3d330G2+350_0O3p2?2%1w2_3u2{040D3z3c3C3e3E3w040M3I3r3K3t3v360F3i1n2W1c2K2x0e1#2C3s0s2S1}1k3#1l3Z2!1d2;053+0!2X3R2N010k0_0!0I3i0C3A3l0I0_1Z0y0e0W0p2n0t2b102P3X3J3}0^040U4j3|2)0_2R0r0q2n4p2@3S4m0T0u3Q4y3}0n0_0C4I443?2 453s0P0e0_020x0W0G0K0N4S4U4W4Y4V0N0C0R1_0Y0G0p1M0d0a0l0s0A2g0W2n2j4;0p2,1M4b0C4t4v4~1a0X0l0C1_0+1z0I0I2n0P4D3B3}4P4H4J4g0%0X0*4#4!4T4$5p0N3p4J444k1=3 040p424L2t5x4q2_0q0_244x5g1=4m4o5E3{4E4r04514w5R4N4z0_0T435Z3}0G0_0E0E5%5y1P0r0p2.5M324m4C5R065w5w5(5z0_2n0K4^1b5R5G5T2_610G4h5n5@3s4m0H6e3S0X4s6b526i4l0_0j5v4J5 1P5A0o1D5D2Y675N69045l2P5e5Y5/0;6g6o5U5W0o6M1P6L6I5H0;5;0_0c6Q6K6q6r666u0;5*04020J4W5-6%6J336a6c6H2!6;6S6_6U6=5V6m5X6|686!046h6T73016W042/776C740j0j5`2Y5|5}4I6(3~610#645.6}6k6E6b5m6^3@6`0_76727e6~6O6Z016{7z6}7a6Y7d5^6#7s786*0B7R7E7u494b4d0o4f7w4i7O6f0_5Q7D3l6l4u717K787J4M6;7a7c7-7*040u0j5$5{5~6;6w0)6P7)5!7~6s7l7n5A627r6:7t480A4a4c4e6F657|897,7=7W7/6n886p757H7`7H5_807V326*0i8F3s7u8o7y7^6}7@2t7n7u7G8x5O7B8A5=047N8q8y7g3z0m3_0o2u2V8,3!1t3$2x2A2v0y1K8/0m3#0{8|0#0%0)04.
Astuce

On peut utiliser des "slices" avec les chaînes de caractères