Aller au contenu

Écrire un nombre en chiffres romains⚓︎

On souhaite dans cet exercice écrire des nombres entiers strictement positifs en chiffres romains.

Cette notation a évolué au fil des siècles. On se propose ici d'utiliser la méthode fixée au Moyen-Âge en se limitant aux entiers inférieurs à \(5\,000\).

1. Symboles utilisés

Les symboles valides sont les suivants :

Valeur Symbole
\(1\) I
\(5\) V
\(10\) X
\(50\) L
\(100\) C
\(500\) D
\(1\,000\) M

Ainsi, MMXII (\(2012\)) est une écriture valide, AM non.

2. Ordre d'écriture

La représentation d'un nombre en chiffres romains se lit de gauche à droite. Dans le cas de base, on y rencontre des symboles de valeurs décroissantes.

Ainsi, XVI est l'écriture valide du nombre \(16\), VIX non.

⚠ La règle n°5 autorise toutefois certaines entorses à cette règle.

3. Notation additive

Dans le cas de base, les valeurs des symboles sont additionnées.

Ainsi LXXIII représente \(50+10+10+1+1+1=73\).

4. Répétitions

Le symbole M peut être répété autant de fois que nécessaire.

Tous les autres symboles ne peuvent pas être répétés plus de 3 fois (inclus).

Ainsi, MMMMVI (\(4\,006\)) est une écriture valide, MMMMIIIIII non.

🧐 Cette règle a été fixée au Moyen-Âge. L'écriture MMMMIIIIII était valide dans l'Antiquité !

5. Notation soustractive

Afin d'éviter les répétitions interdites, on s'autorise des entorses à la règle n°2.

On peut ainsi faire précéder les symboles :

  • X et V par un unique symbole I,
  • C et L par un unique symbole X,
  • M et D par un unique symbole C.

Dans ces cas, la valeur qui précède est soustraite à la valeur précédée.

On a donc les correspondances suivantes :

Symboles Valeurs
IV \(4\)
IX \(9\)
XL \(40\)
... ...

Ainsi, MCMXLI représente \(1\,000+900+40+1=1\,941\).

La fonction pour convertir

Écrire la fonction romain qui prend en argument un nombre entier strictement positif valeur et renvoie son écriture en chiffres romains.

Exemples
Python Console Session
>>> romain(4)
'IV'
>>> romain(5)
'V'
>>> romain(6)
'VI'
>>> romain(5042)
'MMMMMXLII'

###(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 : 5/5

.128013.129300.128203=MyCT32x4,êg7p]v_rb:c8O{A/+ç.D«îitE1m%é»)?*UfzèIoqs5L69à[lSVR;auPkewn-h(d}0X 050~0^0K0;0J0,0#120x0,0;0#0#0d010K0J0q010406050#0=0N0N0;0u0f040-0Z0,0=1j0Z0`12020;0N0q0:120/0^1t0u0!0=0^0#050C1q1s1u1w1o0q04051#1U1(0C1#1o0~0J0s1b1d1f1h1d0`0o0=0;0o0^0{0q0f0K0|1D120|0J0o0|0,270|0K1m05160v0,0^1;1e1g0126282a280K2g2i2e0K0u1$221b1z0#0q0;0`1h0j012k1?010V180^0`1H0^2e2C2E2J2m2M2i2P0N2R040a120?0u0Z0q0Z0#0J1C1E142A0u0u0^0x2:1U2T0`1$0C222 2w2y2x2f0~2V1@0J0`2O2-2e1.1:1c2l393b0`0Z3f2e0q2^1$2}2 3s1p2D1E3h2K3l0u1t0,2e0;252^0V1h030t0t0x3m0^2a3k0Z0{0M3T1m120M1U0;3t3w1n3v2U3y2m3A3C3E3G0^3I013K3M3O3Q3c3T0{2H04120j3Z3#2E3%2}38013,0;3D1$3F0|3H3J3L3N143_3l3{0i3W0i412|3$1o453*1h484a054c4e3=4g3^3a3`3U0l3W0l4p1V4r3(3x1=3+0Z3B493.4d3:4f3@4i4E4k3U0$3W0$4K3s4s3w464w4U4A3?4h3P4!3S3U0(3W0(4*4M4t4P4v4R3-4b3/3;4=4D3R3{0p3W0p4~434,3)5147534T554V574C4Z5a3U0y3W0y5f2~5h4O3i5k4S4x4z4W4B4Y4@5s0{0)3W0)5x444-4u5C544y564X4?4j4_3T101m0M105P5z4.5l5E5W5H5Y4^3{0M0M5%3Y0C3!4q5g4N5,5D4:5G585r4F3T3}0M405{425y5 5S4/5n4;5q5J660M4m046m5*6e5j6g5V5o5X596l4H6o4J6b5}6d505B6t5F5p5I5Z5?4%6o4)6C4L5~6F3z5-626J5;5K0M4{6o4}6Q4+6r6G6V6h636j6L3U0M5c6o5e6(4 5R6s6,6u6i6K5=6;5u6o5w6_6S6{6+616-6X6x4#3T5M6o5O766E786U7a6~6.705K0j5$047s6q6T4Q7n6I6w657e0j5^7u5`5|6R7k5i795U7A5:7d5!0j3}7S7w7l7y7N5/646k7D6n0j4o7j5Q7L7m7Y6v7P7C7R6z0j6B7I3u1+3q1U3f320~2y375S4?3e1/1$3p0^3r3$6D1$4?8a2U0J0~1h3L2}5?3.8h8j7q6l2I2Z0^8p6Y8r2 5|7x4v1m0.0B0%0L0U0/0-8c126*2K0Z1m0d8K8M2m1l040+8c1o7J8f1E8o018k3w3{3}5V8$6/713|8s2Q8v7Q8*2e6b128{8L8A018U0}8c8S1h0N0J5%1098928~8U0m8R8~0#3}021Q0Z0K0:0e9i0=9k0:9a7W1h8U0R9d8Z8Y3u458-0t8l3U6n8,8i8%8q7e4m128t8?7;4l8_3!8|8}9t8 1m918Z9301951m0)999!9b1m9x3s9V7,2m9g1m9o9q0g9n9j9l9s9;9u1m9w8X9~8#9I8(2E3{6z9H9P7#5!4H9N8=9J8w7eaa8`8|9#90a4469%040$9*9A9W9c9e9W9?049^9l0GaD9r9+axa19.4MaI8ga69D8)4$8naPaj5!4%ag2!ac6:0{6N419Uao9Yaq5Sas0lav8b9,04aL439:5A2KaBaG0gaF9|aHaw9 9X04a29yaq9C9E0{6#abai8@4`8;aZbe9Qbg8y3~ana=9Zb2a`2mas5(5)aNbsa0a?azb3a|b00gaGa,5j9va@6dbx12b9aR0{6?bd8.5K5caY8ubjad5b9Sbn8{a*04bqa;9Was9)bH5Bay8Za_46bD9p9l11bFb0b/2KbJa3bMbOa85taTa!8/5ubWc75K73a(boaJb)b~bt96atbwbr46b;9/9#b^9q0%bGbM5Sc0b7c2aPba7gbS9K5!5McabYa#cDamb%bpci94cka/cPb4bK3~cr9hb011cub}cwbIaKc1cnc30`5?7tcEaVc.bhbXbT6lc/cMb?cxa+c%5Bbucmb+b3cp3$c|5jcsb`cvcnc}b5cV9zd3a58pba5@c6cJ8/dlcIc^7edlbma)cOc 2Kb-cTd5a^cX9@b00Y11dbdhcoc)czc+cBbP69dmdr5!dQdqcF5?8+c{b(b*439#as6Pdcc(bAb=dDaCb00.dId$a=b66)cAdjdP9G3F9Cc;6;9M9Odn6Z9GdZdwd*d0cRdA9-bBby01d90:0Yd;c$e9b dLd_dNd{c43Taad~aUbfetc?cb6yb#dvcgd#2~d%ck5`em8Tedd-9fcYb_eid=eGd@dfb8dOes0Ma%eveAdsaXe3dS6Mb#b(0rc*dJc,5?bce#e46l4{dVe03Tbc6bdgd?4-e;6;bRe@e*f4eze^dsbRe eWerc-72dRdWfhe{ex0Mcd6C8~0@1m140VcT0_3WcT0`0V1m2*1t3aecchdx3+1m0s490^0=0ufF0R0we/f1aOff5?cDf6fj7ff9f7f!ducfb30`fB1S0=0,160Kee468O048QeNaAeP9qeS3%d`9Jba7sfie|g3flbk3|c`9Tf)effr040V4Rf=6f1m2O1j0^fOfHbzcVd76G1m0#0f0N0v1z0^gi5j0Zfw04fEf`f*8C8E8G8IfFfRdMe:eXfg3|7Fc:ex7Ef#fZgXf(9UcN9Wge0_262igBgt04fK2ifNg-8N9@0o9lf_cq8~f+04gl0JgngNfSeTf2gR8*8+fYg52Hg7bZ3U7SeCg$hi9#g~g:fMgog|9Wf@0{g{d6hkgk0`gmhoaMeqg1bP7(g4gWe2ahf$hEg#higc4.f,1qf/0;f;gHeff@0DhtdCg}gugwgyg,gPfTdihCes7@hFg8h.hda#h.hL9#ge2^0KfN0`g?fI042^hQf:h42 8e1)7|0C7~1U0K80ic35300;2h897}861!8!462^0N0t0V0;0@0^0t0|6n1M1O1Q1S12gO7`1,131/460;0~0N1D2/0J243agg1m1!iKiMiO2:0{1j0K2u040U1E490o4R2/0|2!120o0,0Z1B1D1)3%1#0z1E3p0Z0x0X2=2=it0E242E490Z1`2j0;0=120H1L2O0~je2=iN0`2Ph1120QiE12jd122afM122=2^0`0~2^122O123piQ0u2/0PjviDjg0q0J0X0xiDjr2i1a0q1A1a0o0u2E140#0mbN0x0Jj)240P0xjJ0KjEi~jJi-0KjLjVjf12hmfN1ajUiDjX0=jZj#jB1S0Fi`1-iJ5S1^1`1|1~0K0^0kj=2o292b2dio5S2X2O2Q1m0c120L0kjX0J0xhSiQ0`1T9!888!6c8d3Oioe;0j3V55d 8@kQ5^h=5=kV2I7/7!6LkZbm0g0u0Pgn120=3b1b0|0;0Ik:2=kDj#2`0XjD0s8h2j15jv02030i0)0:0;0V0V2_kj0u120*jv3FfKjJii2i12k+i3hSf0h5fUh,c-kQh9bNew9QlwgYc;lB7Ze*lBbm0?i@le0xk=iC9N0ZgxjD1B180J0#ll2j0wlrkOh7kQd}lye$3Sl%lCkU0{9Mk#lGl/hh8{0h2Ej=lO1dj~fLfNlf2A0`0sgn1jle1Sj=1q0q0PjJhn2ji@120P0ofLm1jSlPlRlYl!5 kP0{eul)fal+mtl-lAmylFdWkQalgbhi0g1DkDj`3ble0,l4l60:j/j;fN2jfC17k^2jmm3lmojtjelof.f:mq9Bl$a$h/bZkQe(hImDm/mClDm/hL9U1yk52w17jDm!lQ0vjDlgl}j lelg3Nm3m50J0umq0Ci77{ikiaimiI3g5jiLjmiP240_1u0`3a0oiU1%iWntiZi#i%iA1uiCkb1%040.i@1a0;m40WjGfM0K0{0n2w2jlT2a0#jLk/jykC2:jojD058e8D8F8H0-0d120Abv100w12010ej)9)n|019`01j)aun|n~0Go612a/o3a~2I0Foi0 1Ui7n6120C1n0b120g3P3F3Fgg0`2`kF0`jLoikaonop060B2sh01Dj)140q0=lVjGjYh1k0j~gn2.1Dj(jy2EjW21231Ej|1.oz1Dn-iD0#1Dj=2D0u3NfNk5o!kGjv004RjC2j0~o#jMiC0,bN1912o:hxn~mS2/0#2ImglWlVlV0F120-0Jj~nP12n1fK182inT1qlek/2jm40uoXi~jYjtoyh1jnp12j2022oL1b2j0`00m8jG1ejM1b1epli)n*o,jnn2pQpS0#o=pV1p2w1D0o04o o-0P2|p/1_3~n}0,o~0up0o{1a2ip5p9o;mhj:pejM1ao^jXiD0}1c0Pj)na0R9N00ov0=0xpzbN1I4R16oy0^plnOo`k:2,fN2^nT2D1an#lVk-jSoJ120N0PpN2=nR2_jyqn1Bi2lh1_kh0#pl0Yp6it1Bk.1jn$k-qCpyi*0,i,j;i/2ji=i@0K24qrp+0uqph|jDp?jnk,ka1+f 7~8YranpnDiYkFbNfzf@iV5Snsrf1Di!2/i%0eqP23qRq@qO1jnKr8ini}nUq*jd1fpoi 0x0P14m71EqIlWpbj%n*k pD1afM1c8hpI3bnQ2M2;pQpLpVpdjD2=gyqplmn/3O46kf1{1}1 0f252b2q2c2Sg(1mg*2N92njkNplrCj#0q0q3PlmjF3:lbl{1RiEnLf.3%2akMk_5jr@khr`r|2pkps0b3bu0p0l75hpb3f@0C0Ch cQ97a:d$s6143~pT0Pg:0=jLlgr;sq5Bssr_20svko2rsyefbus58ej)0xp*j=lm9|pIj=2=l}3fpj24rW2a1.2OmYgs2K1ui.1tkj0k1m090}0M090msB0y090R8Ko?t42mt622t8kktbtdtf9810tj8KaHso1ososXmZsr2Ekgs#r{knr~kqeH5%thsJ01f@0O8KtnsK6otws-kNjEp+mhsTsV8L4?r?tHr^1~s$tLsxkr5jastQ9!sO89s/s;pWi2kjjymZ15u20N0ni:s|pDr7tB1UsmkcnqsZt.stpMo(s%tMs*46kt8t1m0?o%i_kI7|7`3ui7m-fV0ikRgV9QuEkWe)dWuIk!6 c;uMbmh_fs3:fvfxgp47fAi1lQmXfFeFt@g.nafPiFhAgQuD8:kSlzbZuEhcuKuP8:m`8@u^l@tW47hPm*hStRf@hY2~v1ehf~m,h6u:l(kTuHl?kX5auEl:uOu~l?h^fq1mgghzhZ9Wg~h0h2uXdBv9hv04gvgxgzv6gEgGsEefg~n;gL8JvB1mu-5~g0a7c-uEmuvhu@mBu`vpafl;uLmym}hNgj04s@glv68PtRhll vvvD8~sGsIhUhOg hxh1v|f hBvXl/m|uGv$m?bie*uEaXv+u{a%c{eDgIg/v{v@f^v_fJwqw15StTwtw3hyi5mrh7uEe?mvwgbbmzv$e`wjvpe~mGg$vEi2v4hTvMf?1mhXwzvGh%gAwwgC1m0Twzv=hxtV9#0x7F03m2mK0P2P2:u3pXk{0Kk}1SwCuCluwaf5wHv,bVv(vibVwNxbv0uSi115h}wzwThRwVu.sNnkkJil0sr9no3frenyw{3lkjnB0qxxnuc-nG2#0Lj=0;3p0X1a0SnL1#0%iDvzpCp90=mbmdoUmgmijd0km19#tpi/hSts04tc0$tv98tyb=0#00pdm4pbjFrOl`k.k:0v1ujD23jJ0Wo;mk3a1.1Qy01Q001812q)j=0Nm*1kjwmN2jit2`hnw@gnoBpUlex*rwx-tax/tu0mtwx@3sr7iH1#0?1ujE0k1Nqev1x+tryCtc090ZpB3_0A09t90K0A0.0Y0 0 y$kky(0gy;y*0Yy+yHd62^3p0P0#gl2jyzt7yBtt0(tf0i10titkb=k`pWz1tqz3yDyXyZ4Ey#y%y)y+y-za9/pTylf/yn0JjLtmzex,t9ttteyFx?zq3$yJxuxtrb15171904.
Astuce (1)

Penser à un algorithme glouton.

Astuce (2)

On pourra utiliser la liste VALEURS = [..., (4, "IV"), ...] après l'avoir complétée.

Astuce (3)

On pourra utiliser la liste VALEURS = [(1000, "M"), (900, "CM"), (500, "D"), ...] après l'avoir complétée.