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.128203.129300DT*a3=gMvèuXt«h0xîA[/êàqV8k)ç.éb6rO7+ pR{c?}5zl:ESf(CUms1_i2n]Lwo;ey4%dI9»P,-050|0^0p0g0-0X0*0O0S0X0g0*0*0i010p0-0P010406050*0n0)0)0g0K0_040!0?0X0n1j0?0/0O020g0)0P0@0O0Q0^1t0K0A0n0^0*050x1q1s1u1w1o0P04051#1U1(0x1#1o0|0-0l1b1d1f1h1d0/0j0n0g0j0^120P0_0p0r1D0O0r0-0j0r0X270r0p1m05160I0X0^1;1e1g0126282a280p2g2i2e0p0K1$221b1z0*0P0g0/1h0.012k1?010#180^0/1H0^2e2C2E2J2m2M2i2P0)2R040a0O100K0?0P0?0*0-1C1E142A0K0K0^0S2:1U2T0/1$0x222 2w2y2x2f0|2V1@0-0/2O2-2e1.1:1c2l393b0/0?3f2e0P2^1$2}2 3s1p2D1E3h2K3l0K1t0X2e0g252^0#1h030,0,0S3m0^2a3k0?120+3T1m0O0+1U0g3t3w1n3v2U3y2m3A3C3E3G0^3I013K3M3O3Q3c3T122H040O0.3Z3#2E3%2}38013,0g3D1$3F0r3H3J3L3N143_3l3{0h3W0h412|3$1o453*1h484a054c4e3=4g3^3a3`3U0`3W0`4p1V4r3(3x1=3+0?3B493.4d3:4f3@4i4E4k3U0V3W0V4K3s4s3w464w4U4A3?4h3P4!3S3U0J3W0J4*4M4t4P4v4R3-4b3/3;4=4D3R3{0M3W0M4~434,3)5147534T554V574C4Z5a3U0C3W0C5f2~5h4O3i5k4S4x4z4W4B4Y4@5s120~3W0~5x444-4u5C544y564X4?4j4_3T0s1m0+0s5P5z4.5l5E5W5H5Y4^3{0+0+5%3Y0x3!4q5g4N5,5D4:5G585r4F3T3}0+405{425y5 5S4/5n4;5q5J660+4m046m5*6e5j6g5V5o5X596l4H6o4J6b5}6d505B6t5F5p5I5Z5?4%6o4)6C4L5~6F3z5-626J5;5K0+4{6o4}6Q4+6r6G6V6h636j6L3U0+5c6o5e6(4 5R6s6,6u6i6K5=6;5u6o5w6_6S6{6+616-6X6x4#3T5M6o5O766E786U7a6~6.705K0.5$047s6q6T4Q7n6I6w657e0.5^7u5`5|6R7k5i795U7A5:7d5!0.3}7S7w7l7y7N5/646k7D6n0.4o7j5Q7L7m7Y6v7P7C7R6z0.6B7I3u1+3q1U3f320|2y375S4?3e1/1$3p0^3r3$6D1$4?8a2U0-0|1h3L2}5?3.8h8j7q6l2I2Z0^8p6Y8r2 5|7x4v1m0B0v0;0Z0(0Q0!8c0O6*2K0?1m0i8K8M2m1l040w8c1o7J8f1E8o018k3w3{3}5V8$6/713|8s2Q8v7Q8*2e6b0O8{8L8A018U0$8c8S1h0)0-5%0s98928~8U118R8~0*3}021Q0?0p0@0k9i0n9k0@9a7W1h8U0E9d8Z8Y3u458-0,8l3U6n8,8i8%8q7e4m0O8t8?7;4l8_3!8|8}9t8 1m918Z9301951m0~999!9b1m9x3s9V7,2m9g1m9o9q0%9n9j9l9s9;9u1m9w8X9~8#9I8(2E3{6z9H9P7#5!4H9N8=9J8w7eaa8`8|9#90a4469%040V9*9A9W9c9e9W9?049^9l0daD9r9+axa19.4MaI8ga69D8)4$8naPaj5!4%ag2!ac6:126N419Uao9Yaq5Sas0`av8b9,04aL439:5A2KaBaG0%aF9|aHaw9 9X04a29yaq9C9E126#abai8@4`8;aZbe9Qbg8y3~ana=9Zb2a`2mas5(5)aNbsa0a?azb3a|b00%aGa,5j9va@6dbx0Ob9aR126?bd8.5K5caY8ubjad5b9Sbn8{a*04bqa;9Was9)bH5Bay8Za_46bD9p9l0obFb0b/2KbJa3bMbOa85taTa!8/5ubWc75K73a(boaJb)b~bt96atbwbr46b;9/9#b^9q0;bGbM5Sc0b7c2aPba7gbS9K5!5McabYa#cDamb%bpci94cka/cPb4bK3~cr9hb00ocub}cwbIaKc1cnc30/5?7tcEaVc.bhbXbT6lc/cMb?cxa+c%5Bbucmb+b3cp3$c|5jcsb`cvcnc}b5cV9zd3a58pba5@c6cJ8/dlcIc^7edlbma)cOc 2Kb-cTd5a^cX9@b00}0odbdhcoc)czc+cBbP69dmdr5!dQdqcF5?8+c{b(b*439#as6Pdcc(bAb=dDaCb00BdId$a=b66)cAdjdP9G3F9Cc;6;9M9Odn6Z9GdZdwd*d0cRdA9-bBby01d90@0}d;c$e9b dLd_dNd{c43Taad~aUbfetc?cb6yb#dvcgd#2~d%ck5`em8Tedd-9fcYb_eid=eGd@dfb8dOes0+a%eveAdsaXe3dS6Mb#b(0:c*dJc,5?bce#e46l4{dVe03Tbc6bdgd?4-e;6;bRe@e*f4eze^dsbRe eWerc-72dRdWfhe{ex0+cd6C8~0D1m140#cT0=3WcT0/0#1m2*1t3aecchdx3+1m0l490^0n0KfF0E0Ye/f1aOff5?cDf6fj7ff9f7f!ducfb30/fB1S0n0X160pee468O048QeNaAeP9qeS3%d`9Jba7sfie|g3flbk3|c`9Tf)effr040#4Rf=6f1m2O1j0^fOfHbzcVd76G1m0*0_0)0I1z0^gi5j0?fw04fEf`f*8C8E8G8IfFfRdMe:eXfg3|7Fc:ex7Ef#fZgXf(9UcN9Wge0=262igBgt04fK2ifNg-8N9@0j9lf_cq8~f+04gl0-gngNfSeTf2gR8*8+fYg52Hg7bZ3U7SeCg$hi9#g~g:fMgog|9Wf@12g{d6hkgk0/gmhoaMeqg1bP7(g4gWe2ahf$hEg#higc4.f,1qf/0gf;gHeff@0NhtdCg}gugwgyg,gPfTdihCes7@hFg8h.hda#h.hL9#ge2^0pfN0/g?fI042^hQf:h42 8e1)7|0x7~1U0p80ic35300g2h897}861!8!462^0)0,0#0g0D0^0,0r6n1M1O1Q1S0OgO7`1,131/460g0|0)1D2/0-243agg1m1!iKiMiO2:121j0p2u040(1E490j4R2/0r2!0O0j0X0?1B1D1)3%1#0L1E3p0?0S0m2=2=it0F242E490?1`2j0g0n0O0q1L2O0|je2=iN0/2Ph10O0 iE0Ojd0O2afM0O2=2^0/0|2^0O2O0O3piQ0K2/0HjviDjg0P0-0m0SiDjr2i1a0P1A1a0j0K2E140*11bN0S0-j)240H0SjJ0pjEi~jJi-0pjLjVjf0OhmfN1ajUiDjX0njZj#jB1S0Gi`1-iJ5S1^1`1|1~0p0^0tj=2o292b2dio5S2X2O2Q1m0b0O0Z0tjX0-0ShSiQ0/1T9!888!6c8d3Oioe;0.3V55d 8@kQ5^h=5=kV2I7/7!6LkZbm0%0K0Hgn0O0n3b1b0r0g0uk:2=kDj#2`0mjD0l8h2j15jv02030h0~0@0g0#0#2_kj0K0O0zjv3FfKjJii2i0Ok+i3hSf0h5fUh,c-kQh9bNew9QlwgYc;lB7Ze*lBbm10i@le0Sk=iC9N0?gxjD1B180-0*ll2j0YlrkOh7kQd}lye$3Sl%lCkU129Mk#lGl/hh8{0e2Ej=lO1dj~fLfNlf2A0/0lgn1jle1Sj=1q0P0HjJhn2ji@0O0H0jfLm1jSlPlRlYl!5 kP12eul)fal+mtl-lAmylFdWkQalgbhi0%1DkDj`3ble0Xl4l60@j/j;fN2jfC17k^2jmm3lmojtjelof.f:mq9Bl$a$h/bZkQe(hImDm/mClDm/hL9U1yk52w17jDm!lQ0IjDlgl}j lelg3Nm3m50-0Kmq0xi77{ikiaimiI3g5jiLjmiP240=1u0/3a0jiU1%iWntiZi#i%iA1uiCkb1%040Bi@1a0gm40WjGfM0p120y2w2jlT2a0*jLk/jykC2:jojD058e8D8F8H0!0i0O0Rbv0s0Y0O010kj)9)n|019`01j)aun|n~0do60Oa/o3a~2I0Goi0U1Ui7n60O0x1n0c0O0%3P3F3Fgg0/2`kF0/jLoikaonop060v2sh01Dj)140P0nlVjGjYh1k0j~gn2.1Dj(jy2EjW21231Ej|1.oz1Dn-iD0*1Dj=2D0K3NfNk5o!kGjv004RjC2j0|o#jMiC0XbN190Oo:hxn~mS2/0*2ImglWlVlV0G0O0!0-j~nP0On1fK182inT1qlek/2jm40KoXi~jYjtoyh1jnp12j2022oL1b2j0/00m8jG1ejM1b1epli)n*o,jnn2pQpS0*o=pV1p2w1D0j04o o-0H2|p/1_3~n}0Xo~0Kp0o{1a2ip5p9o;mhj:pejM1ao^jXiD0$1c0Hj)na0E9N00ov0n0SpzbN1I4R16oy0^plnOo`k:2,fN2^nT2D1an#lVk-jSoJ0O0)0HpN2=nR2_jyqn1Bi2lh1_kh0*pl0}p6it1Bk.1jn$k-qCpyi*0Xi,j;i/2ji=i@0p24qrp+0Kqph|jDp?jnk,ka1+f 7~8YranpnDiYkFbNfzf@iV5Snsrf1Di!2/i%0kqP23qRq@qO1jnKr8ini}nUq*jd1fpoi 0S0H14m71EqIlWpbj%n*k pD1afM1c8hpI3bnQ2M2;pQpLpVpdjD2=gyqplmn/3O46kf1{1}1 0_252b2q2c2Sg(1mg*2N92njkNplrCj#0P0P3PlmjF3:lbl{1RiEnLf.3%2akMk_5jr@khr`r|2pkps0b3bu0M0`75hpb3f@0x0xh cQ97a:d$s6143~pT0Hg:0njLlgr;sq5Bssr_20svko2rsyefbus58ej)0Sp*j=lm9|pIj=2=l}3fpj24rW2a1.2OmYgs2K1ui.1tkj0t1m090$0+0911sB0C090E8Ko?t42mt622t8kktbtdtf980stj8KaHso1ososXmZsr2Ekgs#r{knr~kqeH5%thsJ01f@0{8KtnsK6otws-kNjEp+mhsTsV8L4?r?tHr^1~s$tLsxkr5jastQ9!sO89s/s;pWi2kjjymZ15u20)0yi:s|pDr7tB1UsmkcnqsZt.stpMo(s%tMs*46kt8t1m10o%i_kI7|7`3ui7m-fV0hkRgV9QuEkWe)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%gAwwgC1m0fwzv=hxtV9#0S7F03m2mK0H2P2:u3pXk{0pk}1SwCuCluwaf5wHv,bVv(vibVwNxbv0uSi115h}wzwThRwVu.sNnkkJil0lr9no3frenyw{3lkjnB0Pxxnuc-nG2#0Zj=0g3p0m1a0TnL1#0;iDvzpCp90nmbmdoUmgmijd0tm19#tpi/hSts04tc0Vtv98tyb=0*00pdm4pbjFrOl`k.k:0I1ujD23jJ0Wo;mk3a1.1Qy01Q00180Oq)j=0)m*1kjwmN2jit2`hnw@gnoBpUlex*rwx-tax/tu11twx@3sr7iH1#101ujE0t1Nqev1x+tryCtc090?pB3_0R09t90p0R0B0}0U0Uy$kky(0%y;y*0}y+yHd62^3p0H0*gl2jyzt7yBtt0Jtf0h0stitkb=k`pWz1tqz3yDyXyZ4Ey#y%y)y+y-za9/pTylf/yn0-jLtmzex,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.