Anniversaires
On dispose d'un dictionnaire Python dans lequel :
- les clés sont les prénoms de différentes personnes. Il n'y a aucun prénom en double
- les valeurs sont les mois de naissance de ces personnes stockées sous forme de nombres entiers (
1
pour janvier, ... 12
pour décembre)
Par exemple :
Pythonnaissances = {'Nicolas': 10, 'Antoine': 7, 'Camille': 7}
Vous devez écrire une fonction anniversaires(naissances, mois)
prenant en arguments le dictionnaire décrit ci-dessus ainsi qu'un numéro d'un mois et renvoyant une liste contenant les prénoms des personnes nées durant ce mois.
La liste renvoyée doit contenir les prénoms attendus dans un ordre quelconque.
Exemples
>>> anniversaires({'Nicolas': 10, 'Antoine': 7, 'Camille': 7}, 1)
[]
>>> anniversaires({'Nicolas': 10, 'Antoine': 7, 'Camille': 7}, 10)
['Nicolas']
>>> anniversaires({'Nicolas': 10, 'Antoine': 7, 'Camille': 7}, 7)
['Antoine', Camille]
>>> anniversaires({'Nicolas': 10, 'Antoine': 7, 'Camille': 7}, 13)
[]
>>> anniversaires({}, 1)
[]
Tests sur les résultats triés
En Python, la comparaison de listes prend compte de l'ordre des éléments. Ainsi, les listes [0, 1]
et [1, 0]
diffèrent, quand bien même elles contiennent les mêmes valeurs.
Afin de s'assurer que la liste renvoyée par la fonction anniversaires
contient bien les éléments attendus sans avoir à leur imposer un ordre, on compare donc la version triée du résultat à la valeur attendue. Ceci explique les tests sous la forme assert sorted(anniversaires(naissances, mois)) == résultat_attendu
.
.128013kpn(=32v[fah1:-tS6dm]P)c.u_swl,4obiery5g/ 050t0K0q0l0J0E0C0Q0y0E0l0C0C0f010q0J0c010406050C0A0u0u0l0L0M040r0H0E0A0+0H0d050P0=0@0_0{0:0c04051b141e0P1b0:0t0J0i0Z0#0%0)0#0d0O0A0l0O0K0p0c0M0q0m120Q0m0J0O0m0E1G0m0q0.050U0I0E0K1n0$0(011F1H1J1H0q1P1R1N0q0L1c1B0Z0~0C0c0l0d0)0h011T1p010k0W0K0d0l0u0K1N1/1;1_1V1|1R1 210.0a0Q0w0L0H0c0H0C0J110d0Q0S1-0L0L0K0y2m14240d1c0P1B2z1)1+1*1O0t261q0J0d1~2j1N1k1m0!1U2J2L0d0H2P1N0c2s1c2x2z2$0;1:2n2R1`2V0L0^0E1N0l1E2s0k0)030B0B0y2W0K1J2U0H0p0h0p0n0.0n140l2%2*0/2)252,1V2.2:2=2@0K2_012{2}2 312M34340.0h3a3c1;3e2x2I013j0l2;1c2?0m2^2`2|2~0S3t2V3v0g0.0g3z2w3d0:3D3h0)3G3I053K3M3p3O3s2K3u350G0.0G3X153Z3f2+1o3i0H2/3H3l3L3n3N3r3Q3:3S350N0.0N3_2$3!2*3E3(433,3q3P304933350s0.0s4f3d1f2!142P2C0t1+2H3$014o2O1l1c2Z0K2#4x3`3B054o4O250J0t0)2|2x3v373J0Q4W4Y474p324#1^2a0K4*4o3R4r361N0P3b3|3E0b0.0S0k3Y3B0Q4}4G0d0k0.1;0d1l0K0L0C0V2s0C532y563~0)0-040e5k4U3}2S3F0.1 0J0%1;0y0K5j4Q5l3#5n015p0F5s555H5v0d0.0u0H5z5s5m5v5p0x0o5s0:5F5t4(4X014Z2*3v1@4%4)5+4+4@5.4/204;5=4?4q5^2z3b0Q625N4i570.0c5e0C122L0C0B5b5d5f5h0K5M5W1`0H0.0f6k5O1`5p0j0v5#5V3D5;5,1;3T3l6z5?5~353U0Q4:4=3/4-6H4`61636l1V4 040k406q655I5Q044M2V0u6Y3g5I0H0D0.2K6*5u2-5x0V5A0d5C5E2(6r1V5p5!5%5$6}4i6E4!3=6D5*3.486N0p3?6J5`6L7c3;7e6P04637o646+5v6U0J525%7q6=3i6@5z5g6`5D6x6Z5X0.0j7F7r6?6$2s6(7K7y5o0.6v7w6S0)6n040f6p7V6~3%5R5T6|4x7%5J0.714g7Q5)4*770p4c5:7a6F7d4c7g217i4,7k7`3z7p877x4j67696b5D6e0d5c0i696i7=4G7Y0z8l6!5a0c680d0t8p7H5q8w7M6%0H6)5%7W7.040x6w8E6y7|7^4t7{825@4s5_815|6M7k8O866R7-6U2s0q0A0L137$7G8A8c8g8e6f8i6h0J2s8J2(0P4T4y4N4A4K140q4D922F2A0l1Q8 0P4B5$0S0U0W0C04.
# Tests
(insensible à la casse)(Ctrl+I)