Aller au contenu

Python - Bon départ

I. Parcours de listes et de chaînes de caractères⚓︎

Ce paragraphe a principalement été rédigé par Romain Janvier

Rappels sur les parcours de listes et de textes

En Python, il y a principalement 2 méthodes pour parcourir les listes Python (et donc les tableaux) et les textes.

Python
def parcours_par_valeur(donnees):
    for val in donnees:
        print(val)  # Quelque chose avec val
Python Console Session
>>> parcours_par_valeur([3, -2, 4])
3
-2
4
>>> parcours_par_valeur("AVION")
A
V
I
O
N
Python
def parcours_par_indice(donnees):
    for i in range(len(donnees)):
        print(i, donnees[i])  # Quelque chose avec donnees[i] et/ou i
Python Console Session
>>> parcours_par_indice([3, -2, 4])
0 3
1 -2
2 4
>>> parcours_par_indice("AVION")
0 A
1 V
2 I
3 O
4 N
Vous pouvez tester les deux fonctions ici

###(Dés-)Active le code après la ligne # Tests (insensible à la casse)
(Ctrl+I)
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

Lors d'un parcours par valeur, on n'a pas accès à l'indice mais uniquement à la valeur. Pour choisir entre les deux, il faut donc se poser la question suivante : Est-ce que j'ai besoin de connaître l'indice de la valeur que je regarde ?

  • Si la réponse est oui, il faut faire un parcours par indice.
  • Si la réponse est non, vous pouvez utiliser un parcours par valeur. Mais un parcours par indice fonctionnerait aussi.
Exercice 1 : compter(symbole, texte)

Compléter le code de la fonction compter qui prend en paramètre un texte d'un seul caractère symbole ainsi qu'un texte texte et qui renvoie le nombre de fois où symbole apparaît dans texte.

Python Console Session
>>> compter('b', 'bulle')
1
>>> compter('l', 'bulle')
2
>>> compter('v', 'bulle')
0

###(Dés-)Active le code après la ligne # Tests (insensible à la casse)
(Ctrl+I)
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/=d(l+s3x0v2t_f,-Srig5baeP:u)yon4hk6 cwpm1050d0z0n0y0u0f0h0L0M0f0y0h0h0c010n0u0O010406050h0C0P0P0y0t0E040s0F0f0C0+0F0G050b0=0@0_0{0:0O04051b141e0b1b0:0d0u0l0Z0#0%0)0#0G0v0C0y0v0z0r0O0E0n0I120L0I0u0v0I0f1G0I0n0.050U0x0f0z1n0$0(011F1H1J1H0n1P1R1N0n0t1c1B0Z0~0h0O0y0G0)0m011T1p010p0W0z0G0y0P0z1N1/1;1_1V1|1R1 210.0a0L0A0t0F0O0F0h0u110G0L0S1-0t0t0z0M2m14240G1c0b1B2z1)1+1*1O0d261q0u0G1~2j1N1k1m0!1U2J2L0G0F2P1N0O2s1c2x2z2$0;1:2n2R1`2V0t0^0f1N0y1E2s0p0)030o0o0M2W0z1J2U0F0r0w0r0Q0.0Q140y2%2*0/2)252,1V2.2:2=2@0z2_012{2}2 312M340r1@040m3a3c1;3e2x2I013j0y2;1c2?0I2^2`2|2~0S3t2V3v0i0.0i3A2w3d0:3E3h0)3H3J053L3N3p3P3s2K3u350H0.0H3Y153!3f2+1o3i0F2/3I3l3M3n3O3r3R3;3T350w0.0w3`2$3#2*3F3)443-3q3Q304a33350K0.0K4g3d1f2!142P2C0d1+2H3%014p2O1l1c2Z0z2#4y3{3C054p4P250u0d0)2|2x3v373K0L4X4Z484q324$1^2a0z4+4p3S4s361N0b3b3}3F0J0.0S0p3Z3C0L4~4H0G0p0.2~0P0O0n0z0t542y573 0)0-040e5i4V3~2S3G0.0h0E0P0x0~0z5q5k5t5n0q5q563$5l5u045f0j5f5C5J5E0.0D0B5q0:4R5j3E4*014!2*3v3x3+4)4Y5$4,4^5)4:204=5.4@4r5;2z3b0L5~5I4j585b5H5D1`0F0.0c645R1`0P0u0.0k5W5Q4j5#5%1;3U3l6k5/5`353V0L4;4?3:4.6s4{5}5 651V50040p416a615K0G5v6J3g5K0F0N0.2K6O5s2-0.5N5P5Y5r3F5n5V6#5X2(5!5-6l0G3v3@4(6p5_6y0r3@6u5?6w496_6=3A5 73606P5t6F0u536#756W3i6N7b6D0)67040c697g6b7e045w5y5A6i761`6(6h6#4~6p4#4c6o6.6q6_4d6|216~4-3=346A04747R7c4k637n6K5t7j7m2$7T62040M6V3F7j0g7*4H6d387y6,6j7F7C0r4u6?7F6^7N4u7J5@3/6 7 7P737h016F2s0n0C0t137W7v7p7)6*5C0b4U4z4O4B4L140n4E8s2F2A0y1Q8p0b4C5X0S0U0W0h04.

###(Dés-)Active le code après la ligne # Tests (insensible à la casse)
(Ctrl+I)
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/=d(l+s3x0v2t_f,-Srig5baeP:u)yon4hk6 cwpm1050d0z0n0y0u0f0h0L0M0f0y0h0h0c010n0u0O010406050h0C0P0P0y0t0E040s0F0f0C0+0F0G050b0=0@0_0{0:0O04051b141e0b1b0:0d0u0l0Z0#0%0)0#0G0v0C0y0v0z0r0O0E0n0I120L0I0u0v0I0f1G0I0n0.050U0x0f0z1n0$0(011F1H1J1H0n1P1R1N0n0t1c1B0Z0~0h0O0y0G0)0m011T1p010p0W0z0G0y0P0z1N1/1;1_1V1|1R1 210.0a0L0A0t0F0O0F0h0u110G0L0S1-0t0t0z0M2m14240G1c0b1B2z1)1+1*1O0d261q0u0G1~2j1N1k1m0!1U2J2L0G0F2P1N0O2s1c2x2z2$0;1:2n2R1`2V0t0^0f1N0y1E2s0p0)030o0o0M2W0z1J2U0F0r0K0r0Q0.0Q140y2%2*0/2)252,1V2.2:2=2@0z2_012{2}2 312M340r1@040m3a3c1;3e2x2I013j0y2;1c2?0I2^2`2|2~0S3t2V3v0i0.0i3A2w3d0:3E3h0)3H3J053L3N3p3P3s2K3u350H0.0H3Y153!3f2+1o3i0F2/3I3l3M3n3O3r3R3;3T350w0.0w3`2$3#2*3F3)443-3q3Q304a33350K0.0K4g3d1f2!142P2C0d1+2H3%014p2O1l1c2Z0z2#4y3{3C054p4P250u0d0)2|2x3v373K0L4X4Z484q324$1^2a0z4+4p3S4s361N0b3b3}3F0J0.0S0p3Z3C0L4~4H0G0p0.2~0P0O0n0z0t542y573 0)0-040e5i4V3~2S3G0.0h0E0P0x0~0z5q5k5t5n0q5q563$5l5u045f0j5f5C5J5E0.0D0B5q0:4R5j3E4*014!2*3v3x3+4)4Y5$4,4^5)4:204=5.4@4r5;2z3b0L5~5I4j585b5H5D1`0F0.0c645R1`0P0u0.0k5W5Q4j5#5%1;3U3l6k5/5`353V0L4;4?3:4.6s4{5}5 651V50040p416a615K0G5v6J3g5K0F0N0.2K6O5s2-0.5N5P5Y5r3F5n5V6#5X2(5!5-6l0G3v3@4(6p5_6y0r3@6u5?6w496_6=3A5 73606P5t6F0u536#756W3i6N7b6D0)67040c697g6b7e045w5y5A6i761`6(6h6#4~6p4#4c6o6.6q6_4d6|216~4-3=0r4d5|04747S7c4k637n6K5t7j7m2$7U62040M6V3F7j0g7+4H6d387y6,6j7F7C347E7L5:4t5=7K5^6x7N4u7Q737h016F2s0n0C0t137X7v7p7*6*5C0b4U4z4O4B4L140n4E8s2F2A0y1Q8p0b4C5X0S0U0W0h04.
Exercice 2 : position(val, nombres)

Compléter le code de la fonction position qui prend en paramètre un entier val ainsi qu'une liste d'entiers nombres et renvoie l'indice de la première occurrence de val dans nombres s'il y en a une et None sinon.

Python Console Session
>>> position(7, [5, -1, 7, 4, 6, 4, 2])
2
>>> position(4, [5, -1, 7, 4, 6, 4, 2])
3
>>> position(0, [5, -1, 7, 4, 6, 4, 2])
None

###(Dés-)Active le code après la ligne # Tests (insensible à la casse)
(Ctrl+I)
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/=d(ls3v2t_f,-Srig85[baeP:u)yon4hk cwp]Nm1050d0y0k0x0r0f0g0J0K0f0x0g0g0c010k0r0M010406050g0B0P0P0x0q0D040p0E0f0B0+0E0F050b0=0@0_0{0:0M04051b141e0b1b0:0d0r0i0Z0#0%0)0#0F0s0B0x0s0y0o0M0D0k0H120J0H0r0s0H0f1G0H0k0.050U0w0f0y1n0$0(011F1H1J1H0k1P1R1N0k0q1c1B0Z0~0g0M0x0F0)0j011T1p010m0W0y0F0x0P0y1N1/1;1_1V1|1R1 210.0a0J0z0q0E0M0E0g0r110F0J0S1-0q0q0y0K2m14240F1c0b1B2z1)1+1*1O0d261q0r0F1~2j1N1k1m0!1U2J2L0F0E2P1N0M2s1c2x2z2$0;1:2n2R1`2V0q0^0f1N0x1E2s0m0)030l0l0K2W0y1J2U0E0o0t0o0Q0.0Q140x2%2*0/2)252,1V2.2:2=2@0y2_012{2}2 312M340o1@040j3a3c1;3e2x2I013j0x2;1c2?0H2^2`2|2~0S3t2V3v0h0.0h3A2w3d0:3E3h0)3H3J053L3N3p3P3s2K3u350G0.0G3Y153!3f2+1o3i0E2/3I3l3M3n3O3r3R3;3T350u0.0u3`2(1h2!142P2C0d1+2H3%013Q221c4l1d4j4h2(4s2#2*0J0r0d0)2|2x3v373K4D4F013/49324J1^2a0y4G48304a33354K3Y3$3 0)0I0.0S0m3Z3C0J3}3F0F0m0.2i2k2v3{3C4=4q0-040e4/2y4 4)3G0.0i3I544B3g57510n5c4;4(2S58042V0P0w2s0g5c565l510C0A5c0:4}553E4E4W4I353x3+4M4W4s3S4!3w4T204V4O4X5N3v5I0b3b0J5!5j4C4q4+040m415i5u2-0.0r5-5k1`0E0L5:135B045$5e5l0F0w0.0q1;1w5t5?1V51535|5.3i620429675%5f0.6b2(683(0.5o5q0y5s6c6o015w5x5z6i255E5T5G0o3V4L6D4P4Y4R353V0J4U5L3:6M6G1N5Y5}5#6Y6d4*5:4.5|5~3~606q0E5p5r6B6*1`510v6:4?5:6^500.0N5=6j5l0E0.0c0c6 5 5/045a0f6{6k045y5|5A6n4C6J0l6F3@6I4N6K5V3?5Q216R4Q3=0o7n3A6Y7B5#6!015)2s0k0B0q5{2$6)6_045;7g6^7k6F4d7o7v6L7x4d6P5R7X7r0o7V7A7D6w7G0T7J7L3d7N5(0K0.0O120y6A6c0b4A1f4j0b4v2A4n142D870x1Q0y2z4l5A0S0U0W0g04.

###(Dés-)Active le code après la ligne # Tests (insensible à la casse)
(Ctrl+I)
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/=d(ls3v29t_f,-Srig5[baeP:u)yon4hk cwp]Nm1050d0y0l0x0s0f0g0J0K0f0x0g0g0c010l0s0M010406050g0B0P0P0x0r0D040q0E0f0B0+0E0F050b0=0@0_0{0:0M04051b141e0b1b0:0d0s0i0Z0#0%0)0#0F0t0B0x0t0y0p0M0D0l0H120J0H0s0t0H0f1G0H0l0.050U0w0f0y1n0$0(011F1H1J1H0l1P1R1N0l0r1c1B0Z0~0g0M0x0F0)0j011T1p010n0W0y0F0x0P0y1N1/1;1_1V1|1R1 210.0a0J0z0r0E0M0E0g0s110F0J0S1-0r0r0y0K2m14240F1c0b1B2z1)1+1*1O0d261q0s0F1~2j1N1k1m0!1U2J2L0F0E2P1N0M2s1c2x2z2$0;1:2n2R1`2V0r0^0f1N0x1E2s0n0)030m0m0K2W0y1J2U0E0p0k0p0Q0.0Q140x2%2*0/2)252,1V2.2:2=2@0y2_012{2}2 312M340p1@040j3a3c1;3e2x2I013j0x2;1c2?0H2^2`2|2~0S3t2V3v0h0.0h3A2w3d0:3E3h0)3H3J053L3N3p3P3s2K3u350G0.0G3Y153!3f2+1o3i0E2/3I3l3M3n3O3r3R3;3T350u0.0u3`2(1h2!142P2C0d1+2H3%013Q221c4l1d4j4h2(4s2#2*0J0s0d0)2|2x3v373K4D4F013/49324J1^2a0y4G48304a33354K3Y3$3 0)0I0.0S0n3Z3C0J3}3F0F0n0.2i2k2v3{3C4=4q0-040e4/2y4 4)3G0.0i3I544B3g57510o5c4;4(2S58042V0P0w2s0g5c565l510C0A5c0:4}553E4E4W4I353x3+4M4W4s3S4!3w4T204V4O4X5N3v5I0b3b0J5!5j4C4q4+040n415i5u2-0.0s5-5k1`0E0L5:135B045$5e5l0F0w0.0r1;1w5t5?1V51535|5.3i620429675%5f0.6b2(683(0.5o5q0y5s6c6o015w5x5z6i255E5T5G0p3V4L6D4P4Y4R353V0J4U5L3:6M6G1N5Y5}5#6Y6d4*5:4.5|5~3~606q0E5p5r6B6*1`510v6:4?5:6^500.0N5=6j5l0E0.0c0c6 5 5/045a0f6{6k045y5|5A6n4C6J0m6F3@6I4N6K5V3?5Q216R4Q3=0p7n3A6Y7B5#6!015)2s0l0B0r5{2$6)6_045;7g6^7k6F4d7o7v6L7x4d6P5R7X7r0p7V7A7D6w7G0T7J7L3d7N5(0K0.0O120y6A6c0b4A1f4j0b4v2A4n142D870x1Q0y2z4l5A0S0U0W0g04.
Sortie anticipée

Dans cet exercice nous avons un return dans la boucle. il y a donc sortie anticipée de la boucle s'il n'est pas nécessaire de la terminer.

Ce procédé est souvent utilisé et permet de gagner en efficacité.

Parcours en sens inverse

Il est parfois utile de parcourir une liste Python, ou un texte, en partant du dernier élément et en allant vers le premier. On rappelle que l'indice du dernier élément est n-1, où n est la longueur de la liste ou du texte.

On peut parcourir les indices dans l'ordre inverse en utilisant les paramètres supplémentaires de range. Pour rappel, range(de, vers, pas) part de de et va de pas en pas jusqu'à vers, en s'arrêtant juste avant de l'atteindre. En mettant -1 pour le pas, on parcourt les nombres dans l'ordre inverse.

Python
def parcours_inverse1(donnees):
    for i in range(len(donnees)-1, -1, -1): # on part du dernier indice 
        print(i, donnees[i])
Python Console Session
>>> parcours_inverse1([3, -2, 4])
2 4
1 -2
0 3
>>> parcours_inverse1("AVION")
4 N
3 O
2 I
1 V
0 A

Si on ne veut pas utiliser les paramètres supplémentaires de range, il faut calculer l'indice de l'élément regardé à chaque tour de boucle. Si on note i la variable de boucle, n la longueur de la liste ou du texte, alors à chaque tour de boucle, il faut regarder l'élément d'indice n-1-i.

Python
def parcours_inverse2(donnees):
    n = len(donnees)
    for i in range(n):
        indice = n - 1 - i
        print(indice, donnees[indice])
Python Console Session
>>> parcours_inverse2([3, -2, 4])
2 4
1 -2
0 3
>>> parcours_inverse2("AVION")
4 N
3 O
2 I
1 V
0 A
Vous pouvez tester les deux fonctions ici

###(Dés-)Active le code après la ligne # Tests (insensible à la casse)
(Ctrl+I)
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

Vous pouvez utiliser ces parcours, ou pas, pour l'exercice suivant.

Exercice 3 : derniere_position(val, nombres)

Compléter le code de la fonction derniere_position qui prend en paramètre un entier val ainsi qu'une liste d'entiers nombres et renvoie l'indice de la dernière occurrence de val dans nombres s'il y en a une et None sinon.

Python Console Session
>>> derniere_position(7, [5, -1, 7, 4, 6, 4, 2])
2
>>> derniere_position(4, [5, -1, 7, 4, 6, 4, 2])
5
>>> derniere_position(0, [5, -1, 7, 4, 6, 4, 2])
None

###(Dés-)Active le code après la ligne # Tests (insensible à la casse)
(Ctrl+I)
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/=d(ls3v2t_f,-Srig5[baeP:u)yon4hk cwp]Nm1050d0x0k0w0r0f0g0I0J0f0w0g0g0c010k0r0L010406050g0A0O0O0w0q0C040p0D0f0A0*0D0E050b0;0?0^0`0/0L04051a131d0b1a0/0d0r0i0Y0!0$0(0!0E0s0A0w0s0x0o0L0C0k0G110I0G0r0s0G0f1F0G0k0-050T0v0f0x1m0#0%011E1G1I1G0k1O1Q1M0k0q1b1A0Y0}0g0L0w0E0(0j011S1o010m0V0x0E0w0O0x1M1.1:1^1U1{1Q1~200-0a0I0y0q0D0L0D0g0r100E0I0R1,0q0q0x0J2l13230E1b0b1A2y1(1*1)1N0d251p0r0E1}2i1M1j1l0Z1T2I2K0E0D2O1M0L2r1b2w2y2#0:1/2m2Q1_2U0q0@0f1M0w1D2r0m0(030l0l0J2V0x1I2T0D0o0P0t330-0P130w2$2)0.2(242+1U2-2/2;2?0x2^012`2|2~302L33351?040j393b1:3d2w2H013i0w2:1b2=0G2@2_2{2}0R3s2U3u0o0h0-0h3z2v3c0/3D3g0(3G3I053K3M3o3O3r2J3t340o0F0-0F3Y143!3e2*1n3h0D2.3H3k3L3m3N3q3Q3;3S3?0t0-0t3{2%1g2Z132O2B0d1*2G3%013P211b4m1c4k4i2%4t2!2)0I0r0d0(2{2w3T0P3k4F4H492 4b323?4L0I290x4O4t3R4S354L2y3a3~3E0H0-0R0m3Z3B0I4*4r0E0m4-0x0q0E0r4{0x0l2h2j2u3|3B4?400(0,040e4:2x572R3F0-0i3H5d4C3f58015a0n5l4=3$5o0E0-2U0O0v2r0g5l5f1_5a0B0z5l0/555e3D4N014I2)3T3w3+4E4G5P4P4!5S1@4W4Y3:315!4(040I5-5t4D4r4,040m425s5E3h0-0r5_5u5g0D0K5|125L5,5`3(0v0-0q1:1v5D5 5F0-5c65673F6904286e5:5o5a6i2%6f5{045y5A0x5C6j6v590-0B6p5n600-0o6H3 5g0O0r376M3E5q5~6q6J046L6C6W1_6P6R6!6I6g045r655/6*1U0D6K6S4r6%04386)6N6+5H5J6S5O5Q1:3T3V3J5V5%4a5)3?3V4V1 4X5X4Z4R751M0b3a5.7o6/6}1U5=0r4/6.6k5w6x0D5z5B6@6r0-0u7D5g7y5}6|6T0-0M6V6:0(6=040c0c7P7r3(5i5k7L4r5a5I655K6u4D720l4J3?3^777-7i7b353^7e20794Q7^3@7l7n7p836k5=2r0k0A4|7W3E7J707L7-7/354e7=5W3/7a3=8i5#7f7}5Z4d815,5.856a0S89642#7q4+0J0-0N110x8e4i4B1e4k0b4w2z4o132C8U0w1P0x2y4m5K0R0T0V0g04.

###(Dés-)Active le code après la ligne # Tests (insensible à la casse)
(Ctrl+I)
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/=d(ls3v2t_f,-Srig5[baeP:u)yon4hk6 cwp]Nm1050d0x0k0w0r0f0g0J0K0f0w0g0g0c010k0r0M010406050g0A0P0P0w0q0C040p0D0f0A0+0D0E050b0=0@0_0{0:0M04051b141e0b1b0:0d0r0i0Z0#0%0)0#0E0s0A0w0s0x0o0M0C0k0G120J0G0r0s0G0f1G0G0k0.050U0v0f0x1n0$0(011F1H1J1H0k1P1R1N0k0q1c1B0Z0~0g0M0w0E0)0j011T1p010m0W0x0E0w0P0x1N1/1;1_1V1|1R1 210.0a0J0y0q0D0M0D0g0r110E0J0S1-0q0q0x0K2m14240E1c0b1B2z1)1+1*1O0d261q0r0E1~2j1N1k1m0!1U2J2L0E0D2P1N0M2s1c2x2z2$0;1:2n2R1`2V0q0^0f1N0w1E2s0m0)030l0l0K2W0x1J2U0D0o0Q0I340.0Q140w2%2*0/2)252,1V2.2:2=2@0x2_012{2}2 312M34361@040j3a3c1;3e2x2I013j0w2;1c2?0G2^2`2|2~0S3t2V3v0o0h0.0h3A2w3d0:3E3h0)3H3J053L3N3p3P3s2K3u350o0F0.0F3Z153#3f2+1o3i0D2/3I3l3M3n3O3r3R3=3T3@0t0.0t3|2(1h2!142P2C0d1+2H3(013Q221c4n1d4l4j2(4u2#2*0J0r0d0)2|2x3U0Q3l4G4I4a304c333@4M0J2a0x4P4u3S4T364M2z3b3 3F0H0.0S0m3!3C0J4+4s0E0m4.0x0q0E0r4|0x0l2i2k2v3}3C4@410)0-040e4;2y582S3G0.0i3I5e4D3g59015b0n5m4?3%5p0E0.2V0P0v2s0g5m5g1`5b0B0z5m0:565f3E4O014J2*3U3x3,4F4H5Q4Q4#5T1^4X4Z3;325#4)040J5.5u4E4s4-040m435t5F3i0.0r5`5v5h0D0L5}135M5-5{3)0v0.0q1;1w5E605G0.5d66683G6a04296f5;5p5b6j2(6g5|045z5B0x5D6k6w5a0.0B6q5o610.0o6I405h0P0r386N3F5r5 6r6K046M6D6X1`6Q6S6#6J6h045s665:6+1V0D6L6T4s6(04396*6O6,5I5K6T5P5R1;3U3W3K5W5(4b5*3@3W4W204Y5Y4!4S761N0b3b5/7p6:6~1V5?0r4:6/6l5x6y0D5A5C6^6s0.0u7E5h7z5~6}6U0.0N6W6;0)6?040c0c7Q7s3)5j5l7M4s5b5J665L6v4E730l4K3@3_787.7j7c363_7f217a4R7_3^7m7o7q846l5?2s0k0A4}7X3F7K717M7.7:364f7?5X3:7b3?8j5$7g7~5!4e825-5/866b0T8a652$7r4,0K0.0O120x8f4j4C1f4l0b4x2A4p142D8V0w1Q0x2z4n5L0S0U0W0g04.

###(Dés-)Active le code après la ligne # Tests (insensible à la casse)
(Ctrl+I)
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/=d(ls3v2t_f,-Srig5[7baeP:u)yon4hk6 cwp]Nm1050d0y0k0x0r0f0g0K0L0f0x0g0g0c010k0r0N010406050g0B0Q0Q0x0q0D040p0E0f0B0,0E0F050b0?0^0`0|0;0N04051c151f0b1c0;0d0r0i0!0$0(0*0$0F0s0B0x0s0y0o0N0D0k0H130K0H0r0s0H0f1H0H0k0/050V0w0f0y1o0%0)011G1I1K1I0k1Q1S1O0k0q1d1C0!0 0g0N0x0F0*0j011U1q010m0X0y0F0x0Q0y1O1:1=1`1W1}1S20220/0a0K0z0q0E0N0E0g0r120F0K0T1.0q0q0y0L2n15250F1d0b1C2A1*1,1+1P0d271r0r0F1 2k1O1l1n0#1V2K2M0F0E2Q1O0N2t1d2y2A2%0=1;2o2S1{2W0q0_0f1O0x1F2t0m0*030l0l0L2X0y1K2V0E0o0R0v350/0R150x2(2+0:2*262-1W2/2;2?2^0y2`012|2~30322N35371^040j3b3d1=3f2y2J013k0x2=1d2@0H2_2{2}2 0T3u2W3w0o0h0/0h3B2x3e0;3F3i0*3I3K053M3O3q3Q3t2L3v360o0G0/0G3!163$3g2,1p3j0E2:3J3m3N3o3P3s3S3?3U3^0t0/0t3}2%3%2+3G3+473/3r3R314d343^0J0/0J4j3e1g2#152Q2D0d1,2I3)014s2P1m1d2!0y2$4B3~3D054s4S260r0d0*2}2y3V0R3m4!4$4b4t334)1_2b0y4-4s3T4v374*2A3c403G0I0/0T0m3#3D0K504K0F0m530y0q0F0r5e0y0l2j2l2w4U2z59420*0.040e565p3(5r3H0/0i3J5w4Y412T015t0n5E585y5H0F0/2W0Q0w2t0g5E5q5H5t0C0A5E0;5o5F0K4,014%2+3V3y3-5*4#5,4.4`5/4=214@5@4_4u5`4~040K645M4m5a0/2t2j0F0g0y5L5X1{0E0/0c6f5N1{0I0L0/0P136e5(5%2)3F5+5-1=3V3X3L5=4^3=4:3^3X0K4?6F4c6H376C3B65663h5z52040m446l675z5P040r6!6U5H0E0M0/2L6*5G2.0w691=1x5W6m1W5t5v5(6g3j6@042a6{6#5Y0/6 6w772.5Q0E5S5U766+1{5Z5!5$7i2o6y0l4(3^3`6D7q5 6O3_5{226M4/3@377u6R6S65710*6W0r555(6T6=3j7e7g0y5V706|5s0/0u7o4n6/7$4K5t0O6;3G6i040c6k7P7K5A045C0f7)5z5t5#6u7$7q7s374g7v5?3;6N7E0o4g6K5|7C5_4f1O0b3c7I8l7Q7%046a136d7-4K7/7=2%8n686(7n7X4m825.4w4+875^608G8d7B5~6G8a4x626S7@6W2t0k0B5f8t6$690y6b8s80700b4X4C4R4E4O150k4H8=2G2B0x1R8/0b4F5%0T0V0X0g04.
Exercice 4 : indice_egal_valeurs(nombres)

Compléter le code de la fonction indice_egal_valeurs qui prend en paramètre une liste d'entiers nombres et renvoie True s'il existe un indice i tel que nombres[i]==i et False sinon.

Python Console Session
>>> indice_egal_valeur([7, 1, 8])  # nombres[1] = 1
True
>>> indice_egal_valeur([9, -7, 2, 9, 6])  # nombres[2] = 2
True
>>> indice_egal_valeur([1, 2, 3, 4])
False

###(Dés-)Active le code après la ligne # Tests (insensible à la casse)
(Ctrl+I)
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/=d(ls3v29Ft_f-Srig5[TbaeP:u)yon4hk cwp]m1050d0z0m0y0s0f0g0K0L0f0y0g0g0c010m0s0N010406050g0C0P0P0y0r0E040q0F0f0C0+0F0G050b0=0@0_0{0:0N04051b141e0b1b0:0d0s0i0Z0#0%0)0#0G0t0C0y0t0z0p0N0E0m0I120K0I0s0t0I0f1G0I0m0.050U0x0f0z1n0$0(011F1H1J1H0m1P1R1N0m0r1c1B0Z0~0g0N0y0G0)0j011T1p010o0W0z0G0y0P0z1N1/1;1_1V1|1R1 210.0a0K0A0r0F0N0F0g0s110G0K0S1-0r0r0z0L2m14240G1c0b1B2z1)1+1*1O0d261q0s0G1~2j1N1k1m0!1U2J2L0G0F2P1N0N2s1c2x2z2$0;1:2n2R1`2V0r0^0f1N0y1E2s0o0)030n0n0L2W0z1J2U0F0p0Q0k340.0Q140y2%2*0/2)252,1V2.2:2=2@0z2_012{2}2 312M34361@040j3a3c1;3e2x2I013j0y2;1c2?0I2^2`2|2~0S3t2V3v0p0h0.0h3A2w3d0:3E3h0)3H3J053L3N3p3P3s2K3u350p0H0.0H3Z153#3f2+1o3i0F2/3I3l3M3n3O3r3R3=3T3@0u0.0u3|2(1h2!142P2C0d1+2H3(013Q221c4n1d4l4j2(4u2#2*0K0s0d0)2|2x3U0Q3l4G4I4a304c333@4M0K2a0z4P4u3S4T364M2z3b3 3F0J0.0S0o3!3C0K4+4s0G0o0.2K1k0L0z0n0z0t3I0n0i3I0z0C0r4;2y4@410)0-040e5a4D3g5d3G0.2V0P0x2s0g5i5c2S015f0D0B5i0:3}3C4+4O014J2*3U3x3,4F4H5G4Q4#5J1^4X4Z3;325R4)040K5!4?3%5l4-040o435i5$4E4^4{5-5u1`0F0M4{135C2y5.5k5v0G0x0.0r1;1w5t5%5v5f5h5|5j4060620429675/5l6a6j5 2-5n0F5p5r6n6e1`5x5y5A6u5M4P4K3@3W3K6B5O4!4S3U3W4W204Y6I5V3?366F3A5#6W5~6v1V5)0s4:6c6Y3F0G6q6s0z5s6c5?1V5f0v6A5:040s6^6l0.0O5=685@0.0c0c706k605;6:716=0.5z6c5B2(3E5F5H1;3U3_6G7j5P6K3@3_6N215U4b5W7s1N0b3b6X7D6)4s5)2s0m585{2$7F5(0L0.0w0r0C0z6z7a4E7p6D364f7o5N3:7x6S0p4f7u6P7(4R7y7!7A7C5#6;0)7H0T7K766o6!7P040l3I0g7U7f5t0b4C1f4l0b4x2A4p142D8h0y1Q0z2z4n5B0S0U0W0g04.

###(Dés-)Active le code après la ligne # Tests (insensible à la casse)
(Ctrl+I)
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/=d(ls30v2Ft_f-Srig5[TbaeP:u)yon4hk cwp]m1050d0z0m0y0s0f0g0K0L0f0y0g0g0c010m0s0N010406050g0C0P0P0y0r0E040q0F0f0C0+0F0G050b0=0@0_0{0:0N04051b141e0b1b0:0d0s0j0Z0#0%0)0#0G0t0C0y0t0z0p0N0E0m0I120K0I0s0t0I0f1G0I0m0.050U0x0f0z1n0$0(011F1H1J1H0m1P1R1N0m0r1c1B0Z0~0g0N0y0G0)0k011T1p010o0W0z0G0y0P0z1N1/1;1_1V1|1R1 210.0a0K0A0r0F0N0F0g0s110G0K0S1-0r0r0z0L2m14240G1c0b1B2z1)1+1*1O0d261q0s0G1~2j1N1k1m0!1U2J2L0G0F2P1N0N2s1c2x2z2$0;1:2n2R1`2V0r0^0f1N0y1E2s0o0)030n0n0L2W0z1J2U0F0p0k0i0p0Q0.0Q140y2%2*0/2)252,1V2.2:2=2@0z2_012{2}2 312M34361@040k3b3d1;3f2x2I013k0y2;1c2?0I2^2`2|2~0S3u2V3w0p0h0.0h3B2w3e0:3F3i0)3I3K053M3O3q3Q3t2K3v350p0H0.0H3!153$3g2+1o3j0F2/3J3m3N3o3P3s3S3?3U3^0u0.0u3}2(1h2!142P2C0d1+2H3)013R221c4o1d4m4k2(4v2#2*0K0s0d0)2|2x3V383L4G4I013;4c324M1^2a0z4J4b304d333^4N3!3(420)0J0.0S0o3#3D0K403G0G0o0.2K1k0L0z0n0z0t3J0n0j3J0z0C0r4=2y4^4t0-040e5b4E3h4,3H0.2V0P0x2s0g5i5d5l5f0D0B5i0:3~3D4^4H4Z4L3^3y3-4P4Z4v3T4%3x4W204Y4R4!5N3V5I0b3c0K5!4@4+2S014.040o445i5$4F4t0G4|5.5u5(0F0M4|135B2y5/5k5(0G0x0.0r1;1w5t5%1`5f5h5~5j4162640429695:5v0.6d2(6a3j5n0F5p5r6l616b0.0D5x5z6x2n5E5T5G363X4O6G4S4#4U3^3X0K4X5L3=6P6J1N5Y045#6#606g1`5*0s4;6e6%4_6t6v0z5s6e5^6z040v6E6/040s6|5e0.0O5@6r0)0F0.0c0c746m625?6@75015f5y6e5A6q4F6M0n6I3_3m7o5M4$3V3`6S5R6U4T3@363`2z5Z6$7H6^1V5*2s0m595}2$6.4t0J0L0.0w0r0C0z6D7f7n4Q4K2*3V4g6L7%5U7v4f5Q217A6O7C0p7+3B6#7J4-650T7O7b6y7K7U040l3J0g7Z7k5t0b4D1f4m0b4y2A4q142D8l0y1Q0z2z4o5A0S0U0W0g04.
Exercice 5 : moyenne(valeurs)

Compléter le code de la fonction moyenne qui prend en paramètre une liste non vide de nombres valeurs et renvoie la moyenne de ces nombres. On n'utilisera pas la fonction len.

Comparaison de nombres réels

On rappelle que la représentation des nombres réels en Python est basée sur le principe de la virgule flottante et qu'à cause de cela, deux expressions mathématiquement égales ne donnent pas forcément le même résultat en Python.

Pour vérifier le résultat de la fonction moyenne avec le résultat attendu, nous utiiserons la fonction indiscernables qui prend deux nombres et renvoie un booléen indiquant si la distance entre ces deux nombres (mathématiquement la valeur absolue de leur différence) est inférieure à \(10^{-15}\).

Python Console Session
>>> 0.1 * 3 == 0.3  # Erreur de virgule flottante classique
False
>>> indiscernables(0.1*3, 0.3)
True
Python Console Session
>>> moyenne([5])
5.0
>>> moyenne([5, 15, 8])
9.333333333333334
>>> moyenne([5, 15, 10])
10.0

###(Dés-)Active le code après la ligne # Tests (insensible à la casse)
(Ctrl+I)
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/;=d(l+s30v29t_f,-Srig857baeP:u)yon4hk6 cwpm1050e0C0o0B0v0g0i0O0P0g0B0i0i0d010o0v0R010406050i0F0S0S0B0u0H040t0I0g0F0.0I0J050b0^0`0|0~0?0R04051e171h0b1e0?0e0v0l0$0(0*0,0(0J0w0F0B0w0C0s0R0H0o0L150O0L0v0w0L0g1J0L0o0;050X0A0g0C1q0)0+011I1K1M1K0o1S1U1Q0o0u1f1E0$110i0R0B0J0,0m011W1s010q0Z0C0J0B0S0C1Q1=1@1|1Y1 1U22240;0a0O0D0u0I0R0I0i0v140J0O0V1:0u0u0C0P2p17270J1f0b1E2C1,1.1-1R0e291t0v0J212m1Q1n1p0%1X2M2O0J0I2S1Q0R2v1f2A2C2)0@1?2q2U1}2Y0u0{0g1Q0B1H2v0q0,030p0p0P2Z0C1M2X0I0s0m0j0s0T0;0O0T170B2*2-0=2,282/1Y2;2?2^2`0C2|012~3032342P37391`040O0m3f3h1@3j2A2L013o0B2@1f2_0L2{2}2 310V3y2Y3A0s0j3c0j3G2z3i0?3K3m0,3N3P053R3T3u3V3x2N3z380s0K3c0K3)183+3k2.1r3n0I2=3O3q3S3s3U3w3X3{3Z3}0y3c0y422)3,2-3L3:4c3@3v3W334i363}0N3c0N4o443-473/493p3Q3r3t4w3`353!0z3c0z4F3I4q3l4I3M4K4b4M4d4O3_4h4R3}0x3c0x4W2B4Y462V4#4a3;3?4e3^4g4y4-390n3c0n4=3J4r3.4`4L3=4N4f4x3Y4A390T0k0;5k571i2%172S2F0e1.2K5a4x2R1o1f2$0C2(3i3*3I054x5E280v0e0,2 2A3!3b4M5M5O505h5R1{2d0C5V5g4z5Y2C3g453L0M0;0V0q5G2B0O5,5a0J0q0;2N1n0i0P0C0u221T0C0i5=5K4^1}0:040f675^4!0J0;2Y0S0A2v3e435H4H4_6b0r675@6q2:6i0I6k2v3F6o2B6f6r0;0G0E670?6D680O5U015P2-3!3C5d6P4+513|3B5Z235#6Q5W5(3}6U0b3g0O6/6v594!5.042v0o0F626u6F2:0A0;0B0A666M6~1Y6b6d756w3n6y6A0C6n2)6;4Z4_0I0;0s6}7b3/7d6l0C6C2+7p016b0G7o6=7k0;020g0o0c7A7j1}0S5{040T1A0T4n6M6L7v4r6W0p5Q3}3$5T5N6(5%523#6#245$4Q6Z7*5*3j7a7V7$6R1@3!3 7#7-4,7/3 0O5!7~6Y4j397|3)7w6@5:7I693n7M0S0I0H212O6e7w788m7B6x040l3O0C6{747U7J776H6J7S8p5L7^7X6S4k3q7W7(7/4l826$845X8J7;6:7i8e7q040i6z248d3L7l040d8%5a0S0v0;0k6K8E2q7W7Y394C7}7%7.860s4C8P7,8}7 8 8{3G8V768Y0J0A0p2Y0o658,4!8)8+6M8W3L8.8:8=7?8F5V8_0s4T8|6X8S394T926%9z6*9B1Q6-3D6:9a016@0q499i4_6h049f0C9R1}0I0Q5|169m9M9T8t1U8w8?3L6b8C4p9-8^8I394/9y6)7)4/9D8R9G0s9_988V9L7w9T8!0`9W9%7w9k9X7c8Z8#aa7h9M8)0hae9b0I9g9r8y8@8G9v549`8M8 549~94855i0sawa3a49n5_6i9d9V8x3iaJ9j0;9laja6aL9eap9hab8q1Yalan019p7Nar5F3K9?7`3}5k8K8GayaEa=aB9F7)a=8Ua5a#0,6@6_6{9$aUb13M0;a88$a!8z0,8)0ba(9T9caX9gaO4X6e0b5J5p5D5r5A170o5ubw2I2D721U2C5s6L0V0X0Z0i04.

###(Dés-)Active le code après la ligne # Tests (insensible à la casse)
(Ctrl+I)
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/;=d(l+s30v29t_f,-Srig857baeP:u)yon4hk6 cwpm1050e0C0o0B0v0g0i0O0P0g0B0i0i0d010o0v0R010406050i0F0S0S0B0u0H040t0I0g0F0.0I0J050b0^0`0|0~0?0R04051e171h0b1e0?0e0v0l0$0(0*0,0(0J0w0F0B0w0C0s0R0H0o0L150O0L0v0w0L0g1J0L0o0;050X0A0g0C1q0)0+011I1K1M1K0o1S1U1Q0o0u1f1E0$110i0R0B0J0,0m011W1s010q0Z0C0J0B0S0C1Q1=1@1|1Y1 1U22240;0a0O0D0u0I0R0I0i0v140J0O0V1:0u0u0C0P2p17270J1f0b1E2C1,1.1-1R0e291t0v0J212m1Q1n1p0%1X2M2O0J0I2S1Q0R2v1f2A2C2)0@1?2q2U1}2Y0u0{0g1Q0B1H2v0q0,030p0p0P2Z0C1M2X0I0s0m0K0s0T0;0O0T170B2*2-0=2,282/1Y2;2?2^2`0C2|012~3032342P37391`040O0m3f3h1@3j2A2L013o0B2@1f2_0L2{2}2 310V3y2Y3A0s0j3c0j3G2z3i0?3K3m0,3N3P053R3T3u3V3x2N3z380s0K3c0K3)183+3k2.1r3n0I2=3O3q3S3s3U3w3X3{3Z3}0y3c0y422)3,2-3L3:4c3@3v3W334i363}0N3c0N4o443-473/493p3Q3r3t4w3`353!0z3c0z4F3I4q3l4I3M4K4b4M4d4O3_4h4R3}0x3c0x4W2B4Y462V4#4a3;3?4e3^4g4y4-390n3c0n4=3J4r3.4`4L3=4N4f4x3Y4A390T0k0;5k571i2%172S2F0e1.2K5a4x2R1o1f2$0C2(3i3*3I054x5E280v0e0,2 2A3!3b4M5M5O505h5R1{2d0C5V5g4z5Y2C3g453L0M0;0V0q5G2B0O5,5a0J0q0;2N1n0i0P0C0u221T0C0i5=5K4^1}0:040f675^4!0J0;2Y0S0A2v3e435H4H4_6b0r675@6q2:6i0I6k2v3F6o2B6f6r0;0G0E670?6D680O5U015P2-3!3C5d6P4+513|3B5Z235#6Q5W5(3}6U0b3g0O6/6v594!5.042v0o0F626u6F2:0A0;0B0A666M6~1Y6b6d756w3n6y6A0C6n2)6;4Z4_0I0;0s6}7b3/7d6l0C6C2+7p016b0G7o6=7k0;020g0o0c7A7j1}0S5{040T1A0T4n6M6L7v4r6W0p5Q3}3$5T5N6(5%523#6#245$4Q6Z7*5*3j7a7V7$6R1@3!3 7#7-4,7/3 0O5!7~6Y4j397|3)7w6@5:7I693n7M0S0I0H212O6e7w788m7B6x040l3O0C6{747U7J776H6J7S8p5L7^7X6S4k3q7W7(7/4l826$845X8J7;6:7i8e7q040i6z248d3L7l040d8%5a0S0v0;0k6K8E2q7W7Y394C7}7%7.860s4C8P7,8}7 8 8{3G8V768Y0J0A0p2Y0o658,4!8)8+6M8W3L8.8:8=7?8F5V8_0s4T8|6X8S394T926%9z6*9B1Q6-3D6:9a016@0q499i4_6h049f0C9R1}0I0Q5|169m9M9T8t1U8w8?3L6b8C4p9-8^8I394/9y6)7)4/9D8R9G0s9_988V9L7w9T8!0`9W9%7w9k9X7c8Z8#aa7h9M8)0hae9b0I9g9r8y8@8G9v549`8M8 549~94855i0sawa3a49n5_6i9d9V8x3iaJ9j0;9laja6aL9eap9hab8q1Yalan019p7Nar5F3K9?7`3}5k8K8GayaEa=aB9F7)a=8Ua5a#0,6@6_6{9$aUb13M0;a88$a!8z0,8)0ba(9T9caX9gaO4X6e0b5J5p5D5r5A170o5ubw2I2D721U2C5s6L0V0X0Z0i04.
Exercice 6 : moyenne_ponderee(valeurs)

Compléter le code de la fonction moyenne_ponderee qui prend en paramètre une liste non vide valeurs de couples de nombres (note, coeff) et renvoie la moyenne pondérée correspondant à ces notes. On suppose que tous les coefficients sont positifs et qu'il y a au moins un coefficient non nul.

Calcul d'une moyenne pondérée

Pour calculer une moyenne pondérée, il faut aditionner le produit de chacune des notes avec le coefficient correspondant et diviser par la somme des coefficients.

Par exemple, avec 5 notes \(n_1\), \(n_2\), ..., \(n_5\) et les coefficients correspondants \(c_1\), \(c_2\), ..., \(c_5\), la moyenne pondérée est :

\(\dfrac{n_1\times c_1 + n_2\times c_2 + n_3\times c_3 + n_4\times c_4 + n_5\times c_5}{c_1+c_2+c_3+c_4+c_5}\)

Parcours d'une liste de couples

On rappelle que lors d'un parcours par valeur d'une liste composée de couples, on peut décomposer chacun des couples de la manière suivante :

Python
def parcours_liste_couples(couples):
    for a, b in couples: # (1)
        print(a, b)
  1. On peut aussi écrire for (a, b) in couples . Les parenthèses sont facultatives pour les tuples.
Python Console Session
>>> parcours_liste_couples([("voiture", 3), ("vélo", 5), ("moto", 1)])
voiture 3
vélo 5
moto 1
Python Console Session
>>> moyenne_ponderee([(5, 1), (15, 1)])
10.0
>>> moyenne_ponderee([(5, 1), (15, 2)]) # 5*1 + 15*2 = 35 -> 35/3
11.666666666666666
>>> moyenne_ponderee([(5, 1), (15, 3)]) # 5*1 + 15*3 = 50 -> 50/4
12.5
>>> moyenne_ponderee([(5, 1), (15, 3), (20, 0)]) # le coeff 0 ne compte pas
12.5

###(Dés-)Active le code après la ligne # Tests (insensible à la casse)
(Ctrl+I)
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/;=d(l+s30v29t_f,-Srig857baeP:u*)yon4hk6 cwpm1050e0C0o0B0v0g0i0P0Q0g0B0i0i0d010o0v0S010406050i0F0T0T0B0u0I040t0J0g0F0/0J0K050b0_0{0}0 0@0S04051f181i0b1f0@0e0v0l0%0)0+0-0)0K0w0F0B0w0C0s0S0I0o0M160P0M0v0w0M0g1K0M0o0=050Y0A0g0C1r0*0,011J1L1N1L0o1T1V1R0o0u1g1F0%120i0S0B0K0-0m011X1t010q0!0C0K0B0T0C1R1?1^1}1Z201V23250=0a0P0D0u0J0S0J0i0v150K0P0W1;0u0u0C0Q2q18280K1g0b1F2D1-1/1.1S0e2a1u0v0K222n1R1o1q0(1Y2N2P0K0J2T1R0S2w1g2B2D2*0^1@2r2V1~2Z0u0|0g1R0B1I2w0q0-030p0p0Q2!0C1N2Y0J0s0m0x0s0U0=0P0U180B2+2.0?2-292:1Z2=2@2_2{0C2}012 3133352Q383a1{040P0m3g3i1^3k2B2M013p0B2^1g2`0M2|2~30320W3z2Z3B0s0j3d0j3H2A3j0@3L3n0-3O3Q053S3U3v3W3y2O3A390s0L3d0L3*193,3l2/1s3o0J2?3P3r3T3t3V3x3Y3|3!3~0y3d0y432*3-2.3M3;4d3^3w3X344j373~0O3d0O4p453.483:4a3q3R3s3u4x3{363#0z3d0z4G3J4r3m4J3N4L4c4N4e4P3`4i4S3~0x3d0x4X2C4Z472W4$4b3=3@4f3_4h4z4.3a0n3d0n4?3K4s3/4{4M3?4O4g4y3Z4B3a0U0k0=5l581j2(182T2G0e1/2L5b4y2S1p1g2%0C2)3j3+3J054y5F290v0e0-302B3#3c4N5N5P515i5S1|2e0C5W5h4A5Z2D3h463M0N0=0W0q5H2C0P5-5b0K0q0=2O1o0i0Q0C0u231U0C0i5?5L4_1~0;040f685_4#0K0=2Z0T0A2w3f445I4I4`6c0r685^6r2;6j0J6l2w3G6p2C6g6s0=0H0E680@6E690P5V015Q2.3#3D5e6Q4,523}3C5!245$6R5X5)3~6V0b3h0P6:6w5a4#5/042w0o0F636v6G2;0A0=0B0A676N6 1Z6c6e766x3o6z6B0C6o2*6=4!4`0J0=0s6~7c3:7e6m0C6D2,7q016c0H7p6?7l0=020g0o0c7B7k1~0T5|040U1B0U4o6N6M7w4s6X0p5R3~3%5U5O6)5(533$6$255%4R6!7+5+3k7b7W7%6S1^3#407$7.4-7:400P5#7 6Z4k3a7}3*7x6^5;7J6a3o7N0T0J0I222P0p2m0K0W2w0C6f7x798t7C6y6_660F7G0B0o757V7K786I6K7T8w5M7_7Y6T4l3r7X7)7:4m836%855Y8R7=6;7j8f7r040i6A250p2Z0o668e3M7m040d8?5b0T0v0=0k6L8M2r7X7Z3a4D7~7(7/870s4D8X7-99809b973H8%778*8,0{0C3x3t0q8F3j8(8@0=8`6N9w8|8~04908L7@8N5W950s4U986Y8!3a4U9e6(9O6+9Q1R6.3E6;9m016^0q4a8{6h6z8;923M6t9*4`6i04329s9;1~0J0R5}179A9#9?2w0_8C8E9.5b6c8K4q9.948Q3a4:9N6*7*4:9S8Z9V0sag9k8%9!7x9?9o8.8:8=a07x8^9z7ia10=av9qax9u3J9B4#8^0h9`7d04axa7aM0=0GaT9=0=9^0q5=9G8G938O9K55ah8U9b55al9g865j0sa,aqaraLaY8+8-9qa!9taP0-aBb33NaFa 9ra#aJ5@9#aNb69?b1919Ha)9Jae3b5ma-9aa@5l7,9Tai7:bt8$as8x1Z6^6`6|9 aDatb89p8/0J8;bc3Ebe0=0bbgbJ8.b1bO7U5G0b5K5q5E5s5B180o5vb*2J2E731V2D5t6M0W0Y0!0i04.

###(Dés-)Active le code après la ligne # Tests (insensible à la casse)
(Ctrl+I)
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/;=d(l+s30v29t_f,-Srig857baeP:u*)yon4hk6 cwpm1050e0C0o0B0v0g0i0P0Q0g0B0i0i0d010o0v0S010406050i0F0T0T0B0u0I040t0J0g0F0/0J0K050b0_0{0}0 0@0S04051f181i0b1f0@0e0v0l0%0)0+0-0)0K0w0F0B0w0C0s0S0I0o0M160P0M0v0w0M0g1K0M0o0=050Y0A0g0C1r0*0,011J1L1N1L0o1T1V1R0o0u1g1F0%120i0S0B0K0-0m011X1t010q0!0C0K0B0T0C1R1?1^1}1Z201V23250=0a0P0D0u0J0S0J0i0v150K0P0W1;0u0u0C0Q2q18280K1g0b1F2D1-1/1.1S0e2a1u0v0K222n1R1o1q0(1Y2N2P0K0J2T1R0S2w1g2B2D2*0^1@2r2V1~2Z0u0|0g1R0B1I2w0q0-030p0p0Q2!0C1N2Y0J0s0m0n0s0U0=0P0U180B2+2.0?2-292:1Z2=2@2_2{0C2}012 3133352Q383a1{040P0m3g3i1^3k2B2M013p0B2^1g2`0M2|2~30320W3z2Z3B0s0j3d0j3H2A3j0@3L3n0-3O3Q053S3U3v3W3y2O3A390s0L3d0L3*193,3l2/1s3o0J2?3P3r3T3t3V3x3Y3|3!3~0y3d0y432*3-2.3M3;4d3^3w3X344j373~0O3d0O4p453.483:4a3q3R3s3u4x3{363#0z3d0z4G3J4r3m4J3N4L4c4N4e4P3`4i4S3~0x3d0x4X2C4Z472W4$4b3=3@4f3_4h4z4.3a0n3d0n4?3K4s3/4{4M3?4O4g4y3Z4B3a0U0k0=5l581j2(182T2G0e1/2L5b4y2S1p1g2%0C2)3j3+3J054y5F290v0e0-302B3#3c4N5N5P515i5S1|2e0C5W5h4A5Z2D3h463M0N0=0W0q5H2C0P5-5b0K0q0=2O1o0i0Q0C0u231U0C0i5?5L4_1~0;040f685_4#0K0=2Z0T0A2w3f445I4I4`6c0r685^6r2;6j0J6l2w3G6p2C6g6s0=0H0E680@6E690P5V015Q2.3#3D5e6Q4,523}3C5!245$6R5X5)3~6V0b3h0P6:6w5a4#5/042w0o0F636v6G2;0A0=0B0A676N6 1Z6c6e766x3o6z6B0C6o2*6=4!4`0J0=0s6~7c3:7e6m0C6D2,7q016c0H7p6?7l0=020g0o0c7B7k1~0T5|040U1B0U4o6N6M7w4s6X0p5R3~3%5U5O6)5(533$6$255%4R6!7+5+3k7b7W7%6S1^3#407$7.4-7:400P5#7 6Z4k3a7}3*7x6^5;7J6a3o7N0T0J0I222P0p2m0K0W2w0C6f7x798t7C6y6_660F7G0B0o757V7K786I6K7T8w5M7_7Y6T4l3r7X7)7:4m836%855Y8R7=6;7j8f7r040i6A250p2Z0o668e3M7m040d8?5b0T0v0=0k6L8M2r7X7Z3a4D7~7(7/870s4D8X7-99809b973H8%778*8,0{0C3x3t0q8F3j8(8@0=8`6N9w8|8~04908L7@8N5W950s4U986Y8!3a4U9e6(9O6+9Q1R6.3E6;9m016^0q4a8{6h6z8;923M6t9*4`6i04329s9;1~0J0R5}179A9#9?2w0_8C8E9.5b6c8K4q9.948Q3a4:9N6*7*4:9S8Z9V0sag9k8%9!7x9?9o8.8:8=a07x8^9z7ia10=av9qax9u3J9B4#8^0h9`7d04axa7aM0=0GaT9=0=9^0q5=9G8G938O9K55ah8U9b55al9g865j0sa,aqaraLaY8+8-9qa!9taP0-aBb33NaFa 9ra#aJ5@9#aNb69?b1919Ha)9Jae3b5ma-9aa@5l7,9Tai7:bt8$as8x1Z6^6`6|9 aDatb89p8/0J8;bc3Ebe0=0bbgbJ8.b1bO7U5G0b5K5q5E5s5B180o5vb*2J2E731V2D5t6M0W0Y0!0i04.
Exercice 7 : effectifs(donnees)

Compléter le code de la fonction effectifs qui prend en paramètre une liste donnees contenant des entiers ou des textes et qui renvoie un dictionnaire qui associe à chaque valeur apparaissant dans donnees le nombre de fois où elle y apparaît (c'est à dire le nombre d'occurences de valeur dans donnees).

Par exemple dans la liste [4, 1, 2, 4, 2, 2, 6] il y a une fois la valeur 1, trois fois la valeur 2, deux fois la valeur 4 et une fois la valeur 6. Le résultat attendu pour cette liste sera donc le dictionnaire {1: 1, 2: 3, 4: 2, 6: 1}.

On rappelle aussi que dans un dictionnaire, l'ordre dans lequel on donne les valeurs n'a pas d'importance. Ainsi, les dictionnaires {1: 1, 2: 3, 4: 2, 6: 1} et {4: 2, 1: 1, 6: 1, 2: 3} sont égaux.

Python Console Session
>>> effectifs([4, 1, 2, 4, 2, 2, 6])
{4: 2, 1: 1, 2: 3, 6: 1}
>>> assert effectifs(["chien", "chat", "chien", "chien", "poisson", "chat"])
{'chien': 3, 'chat': 2, 'poisson': 1}

###(Dés-)Active le code après la ligne # Tests (insensible à la casse)
(Ctrl+I)
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/=d(l+s3v2t_f-Srig85[7baeP:u)yon4hk6 cwp]m1050d0z0l0y0r0f0h0L0M0f0y0h0h0c010l0r0O010406050h0C0Q0Q0y0q0E040p0F0f0C0,0F0G050b0?0^0`0|0;0O04051c151f0b1c0;0d0r0j0!0$0(0*0$0G0s0C0y0s0z0o0O0E0l0I130L0I0r0s0I0f1H0I0l0/050V0x0f0z1o0%0)011G1I1K1I0l1Q1S1O0l0q1d1C0!0 0h0O0y0G0*0k011U1q010n0X0z0G0y0Q0z1O1:1=1`1W1}1S20220/0a0L0A0q0F0O0F0h0r120G0L0T1.0q0q0z0M2n15250G1d0b1C2A1*1,1+1P0d271r0r0G1 2k1O1l1n0#1V2K2M0G0F2Q1O0O2t1d2y2A2%0=1;2o2S1{2W0q0_0f1O0y1F2t0n0*030m0m0M2X0z1K2V0F0o0i0R0o0R0/0R150y2(2+0:2*262-1W2/2;2?2^0z2`012|2~30322N35371^040k3c3e1=3g2y2J013l0y2=1d2@0I2_2{2}2 0T3v2W3x350/0i3C2x3f0;3G3j0*3J3L053N3P3r3R3u2L3w360o0H0/0H3!163$3h2,1p3k0F2:3K3n3O3p3Q3t3T3?3V3^0u0/0u3}2%3%2+3H3+473/3s3S314d343^0K0/0K4j3 3(423*443m3M3o3q4r3=333W0w0/0w4A3E4l3i4D3I4F464H484J3;4c4M3^0t0/0t4R2z1g2#152Q2D0d1,2I3)014s2P1m1d2!0z2$3f3#3E054s52260r0d0*2}2y3W394H5a5c4b4t4(37390L2b0z5j4s3U4v5n1O0b3d403H0J0/0T0n542z0L5A4`0G0n0/3p0n2u0,0n0h5G58412T010.040e5U5J4V0G5D132M0z5T3~554C5X5Z0D0B5U0;5/4.3G5i015d2+3W3z3-0L5~4$5l3@3y1_5q5s4L690o635y040L6k5I5;2.5D0r2 0m5O5Q5U6m4m4`0F0/0c6v5%5X0G0x6p2v5$6n1W5Z0e0D5_6J4m660m5e3^0i3n6S5t4u3W6W5p215r5 5k5u6#5x3d6l6w4U5X5C040n446C6K3*0/0j6{6x4V0F0N0/2L706=6o040d5+0z5-6Q786L0/5^5{3g7k5A6S6U373`5h5b6*6Z5m3_6b6(6d4%6f7r3C6:6:6D1{6@0r5F7k6;5W796 7M7H1W7375147R6|3I6H0F6s0n5P6I7m7Y5Z7j4k7f2o7o614f6X7t676,7?6%227A684e374g2A6/7F857S6}7a6q7#6t7)2)7+0/0v7/4n6~8i4`5Z0P777O7T6A8p8j896r8c0l8l4V5Z8h7*716E8k8D7g0*8n8t6y0/0g8L4V0Q0r3a6P8H7:7^6T7=374x7s7~7`8!7y7}7u6e800o8#7E857N5B5N0Y0z8z5=7i8U8e6R8X7p0o4O8$8,7B8.4O7|6)7_6!3^948;8=6l877Z8v8b7%6u8V3H8B8{7P9s7h048o7X8E1{6z046B9y8I018R8T7k5`8 59918Z0o4*959c7w4*9a8%9d379Q9g8?4`6@2t0l0C0q7W2%9#5(7!7$7(8y9J5$0b574/514;4~150l4@9 2G2B0y1R9|0b4=5`0T0V0X0h04.

###(Dés-)Active le code après la ligne # Tests (insensible à la casse)
(Ctrl+I)
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/=d(l+s3v2t_f-Srig85[7baeP:u)yon4hk6 cwp]m1050d0z0l0y0r0f0h0L0M0f0y0h0h0c010l0r0O010406050h0C0Q0Q0y0q0E040p0F0f0C0,0F0G050b0?0^0`0|0;0O04051c151f0b1c0;0d0r0j0!0$0(0*0$0G0s0C0y0s0z0o0O0E0l0I130L0I0r0s0I0f1H0I0l0/050V0x0f0z1o0%0)011G1I1K1I0l1Q1S1O0l0q1d1C0!0 0h0O0y0G0*0k011U1q010n0X0z0G0y0Q0z1O1:1=1`1W1}1S20220/0a0L0A0q0F0O0F0h0r120G0L0T1.0q0q0z0M2n15250G1d0b1C2A1*1,1+1P0d271r0r0G1 2k1O1l1n0#1V2K2M0G0F2Q1O0O2t1d2y2A2%0=1;2o2S1{2W0q0_0f1O0y1F2t0n0*030m0m0M2X0z1K2V0F0o0i0k0o0R0/0R150y2(2+0:2*262-1W2/2;2?2^0z2`012|2~30322N35371^040k3c3e1=3g2y2J013l0y2=1d2@0I2_2{2}2 0T3v2W3x350/0i3C2x3f0;3G3j0*3J3L053N3P3r3R3u2L3w360o0H0/0H3!163$3h2,1p3k0F2:3K3n3O3p3Q3t3T3?3V3^0u0/0u3}2%3%2+3H3+473/3s3S314d343^0K0/0K4j3 3(423*443m3M3o3q4r3=333W0w0/0w4A3E4l3i4D3I4F464H484J3;4c4M3^0t0/0t4R2z1g2#152Q2D0d1,2I3)014s2P1m1d2!0z2$3f3#3E054s52260r0d0*2}2y3W394H5a5c4b4t4(37390L2b0z5j4s3U4v5n1O0b3d403H0J0/0T0n542z0L5A4`0G0n0/3p0n2u0,0n0h5G58412T010.040e5U5J4V0G5D132M0z5T3~554C5X5Z0D0B5U0;5/4.3G5i015d2+3W3z3-0L5~4$5l3@3y1_5q5s4L690o635y040L6k5I5;2.5D0r2 0m5O5Q5U6m4m4`0F0/0c6v5%5X0G0x6p2v5$6n1W5Z0e0D5_6J4m660m5e3^0i3n6S5t4u3W6W5p215r5 5k5u6#5x3d6l6w4U5X5C040n446C6K3*0/0j6{6x4V0F0N0/2L706=6o040d5+0z5-6Q786L0/5^5{3g7k5A6S6U373`5h5b6*6Z5m3_6b6(6d4%6f7r3C6:6:6D1{6@0r5F7k6;5W796 7M7H1W7375147R6|3I6H0F6s0n5P6I7m7Y5Z7j4k7f2o7o614f6X7t676,7?6%227A684e374g2A6/7F857S6}7a6q7#6t7)2)7+0/0v7/4n6~8i4`5Z0P777O7T6A8p8j896r8c0l8l4V5Z8h7*716E8k8D7g0*8n8t6y0/0g8L4V0Q0r3a6P8H7:7^6T7=374x7s7~7`8!7y7}7u6e800o8#7E857N5B5N0Y0z8z5=7i8U8e6R8X7p0o4O8$8,7B8.4O7|6)7_6!3^948;8=6l877Z8v8b7%6u8V3H8B8{7P9s7h048o7X8E1{6z046B9y8I018R8T7k5`8 59918Z0o4*959c7w4*9a8%9d379Q9g8?4`6@2t0l0C0q7W2%9#5(7!7$7(8y9J5$0b574/514;4~150l4@9 2G2B0y1R9|0b4=5`0T0V0X0h04.

###(Dés-)Active le code après la ligne # Tests (insensible à la casse)
(Ctrl+I)
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/=d(l+s3Ov2ét_f-Srig85[7baeP:u)}yon4h{k6 cwp]m1050d0B0n0A0t0f0h0P0Q0f0A0h0h0c010n0t0S010406050h0E0U0U0A0s0H040r0I0f0E0:0I0J050b0`0|0~100^0S04051g191j0b1g0^0d0t0k0(0*0,0.0*0J0u0E0A0u0B0q0S0H0n0L170P0L0t0u0L0f1L0L0n0?050Z0z0f0B1s0+0-011K1M1O1M0n1U1W1S0n0s1h1G0(130h0S0A0J0.0l011Y1u010p0#0B0J0A0U0B1S1@1_1~1!211W24260?0a0P0C0s0I0S0I0h0t160J0P0X1=0s0s0B0Q2r19290J1h0b1G2E1.1:1/1T0d2b1v0t0J232o1S1p1r0)1Z2O2Q0J0I2U1S0S2x1h2C2E2+0_1^2s2W1 2!0s0}0f1S0A1J2x0p0.030o0o0Q2#0B1O2Z0I0q0i0i0q0V0?0V190A2,2/0@2.2a2;1!2?2^2`2|0B2~01303234362R393b1|040l3g3i1_3k2C2N013p0A2_1h2{0L2}2 31330X3z2!3B390?0i3G2B3j0^3K3n0.3N3P053R3T3v3V3y2P3A3a0q0K0?0K3(1a3*3l2:1t3o0I2@3O3r3S3t3U3x3X3`3Z3|0w0?0w412+3+2/3L3/4b3?3w3W354h383|0O0?0O4n433,463.483q3Q3s3u4v3_373!0y0?0y4E3I4p3m4H3M4J4a4L4c4N3^4g4Q3|0v0?0v4V2D1k2)192U2H0d1:2M3-014w2T1q1h2(0B2*3j3)3I054w562a0t0d0.312C3!3d4L5e5g4f4x4,3b3d0P2f0B5n4w3Y4z5r1S0b3h443L0N0?0X0p582D0P5E4~0J0p0?3t0p2y0:0p0h5K5c452X010=040e5Y5N4Z0J5H172Q0B5X42594G5#5%0F0D5Y0^5?4=3K5m015h2/3!3D3;0P624*5p3{3C1}5u5w4P6d0q675C040P6o5M5^2=5H0t330o5S5U5Y6q4q4~0I0?0c6z5+5#0J0z6t2z5*6r1!5%0e0F6z6A4Y5#0Q5k030P0j2s0S0B150P0A0E0,0t0P0m0Q0s0t2x2t6u0I6w0p5T2z0P0c0P0M0G5}6N4q6a0o5i3|0i3r775x4y3!7b5t255v635o5y7g5B3h6p6U5!1 5G040p486G6O3.0?0k7z6B4Z0I0R0?2P7E6V6s040d5/0B5;757M6P0?5|5 3k7Y5E77793b3~5l5f7l7e5q3}6f7j6h4+6j7)3G7r7r6H7u7J5J7Y7s4r7C7L7t1!7H7J18807|3o6L6`6x6M7!7A5$7W748h767+641_3!4k7*7=6c4i3b4k7i268u7n4j7p6n7`8G8b7B7O6_6{6}0n7T850.5%0x8P82047D8m7U8R0?0T843L6D046F8a8i5-8K6v8f8O8Y8Q8j048T8?8V8X2-8i5%8$8,7F5#8)0g8%4~0U0t3e8l8~8n5n7%0q4B8t7,6i8w9h7:8A9k7?9m9i7_8G814~7v350h0B8U4~5%7X4o8U7$653|4S9j6b8C3b4S8z7k9N7f9K8E9v7`8I3M8d8M6y8{9D0?8`9d8Z9!8W9C4Z90977G6E9?5#999b7Y5~9,2s9I8q4-7c8o7m9U3b4.9R8Ba70q4.2E7q6p9Z7v2x0n0E0s892+9w5,9#8;9c570b5b4?554^52190n4{aC2K2F0A1Vaz0b4_5~0X0Z0#0h04.

II. Les listes⚓︎

Exercice 1⚓︎

Vous devez générer une liste contenant les entiers de 1 à 49 dans l'ordre croissant. Ensuite, votre code doit tirer, sans remise, 6 numéros qu'on stocke dans une liste, puis, toujours sans remise, un dernier numéro (le numéro complémentaire).

Exemple

Votre code affichera la liste des 6 numéros puis le complémentaire comme ceci :

Python Console Session
[31, 3, 12, 45, 13, 27]
18

Attention

Vous pourrez importer le module random. Vous ne devez pas utiliser la fonction choice du module random.

A vous de jouer

###(Dés-)Active le code après la ligne # Tests (insensible à la casse)
(Ctrl+I)
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

Astuce

🌵 Envisagez différentes façons de coder ce problème, utilisant pop, del ou remove ...

Solution avec la méthode pop

C'est la solution préférable.

Python
from random import randint
liste = [i for i in range(1, 50)]
reponse = []
for i in range(6):
    numero = liste.pop(randint(0, len(liste) - 1))
    reponse.append(numero)
print(reponse)
complementaire = liste.pop(randint(0, len(liste) - 1))
print(complementaire)
Solution avec del
Python
from random import randint
liste = [i for i in range(1, 50)]
reponse = []
for i in range(6):
    i = randint(0, len(liste) - 1)
    reponse.append(liste[i])
    del liste[i]
print(reponse)
i = randint(0, len(liste) - 1)
print(liste[i])
Solution avec la méthode remove
Python
from random import randint
liste = [i for i in range(1,50)]
reponse = []
for i in range(6):
    i = randint(0, len(liste) - 1)
    reponse.append(liste[i])
    liste.remove(liste[i])
print(reponse)
i = randint(0, len(liste) - 1)

print(liste[i])

Exercice 2⚓︎

1. On considère le programme suivant :

Python
liste1 = [0]*100
liste2 = [0 for k in range(100)]
liste3 = []
for k in range(100):
    liste3.append(0)

Quel est le contenu de chacune des listes ?

Solution

😀 Utiliser l'éditeur Python pour vérifier les réponses ...

###(Dés-)Active le code après la ligne # Tests (insensible à la casse)
(Ctrl+I)
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

2. Ecrire un programme python permettant de créer les listes suivantes :

a. Une liste contenant 12 fois le chiffre 7.
b. La liste des nombres entiers de 1 à 100.
c. Une liste contenant 50 nombres tirés au sort entre 1 et 6.

A vous de jouer

###(Dés-)Active le code après la ligne # Tests (insensible à la casse)
(Ctrl+I)
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

Solution
Python
from random import randint
liste_a = [7 for _ in range(12)]
liste_b = [i for i in range(1, 101)]
liste_c = [randint(1, 6) for _ in range(50)]
print(liste_a)
print(liste_b)
print(liste_c)

Exercice 3⚓︎

Écrire une fonction sans_doublon qui prend en paramètre une liste de nombres pouvant contenir des nombres répétés plusieurs fois et renvoie la liste ne contenant qu'une fois chaque nombre.

Exemple

Python
>>> sans_doublon([1, 2, 4, 6, 6])
[1, 2, 4, 6]
>>> sans_doublon([2, 5, 7, 7, 7, 9])
[2, 5, 7, 9]
>>> sans_doublon([5, 1, 1, 2, 5, 6, 3, 4, 4, 4, 2])
[5, 1, 2, 6, 3, 4]

Attention

Il est interdit d'utiliser count

Compléter le code ci-dessous

###(Dés-)Active le code après la ligne # Tests (insensible à la casse)
(Ctrl+I)
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/=d(ls3v2t_f-S.rig5[baeP:u)yon4hk6 cwp]m1050d0x0k0w0r0f0g0J0K0f0w0g0g0c010k0r0M010406050g0A0O0O0w0q0C040o0D0f0A0*0D0E050b0;0?0^0`0/0M04051a131d0b1a0/0d0r0i0Y0!0$0(0!0E0s0A0w0s0x0n0M0C0k0G110J0G0r0s0G0f1F0G0k0-050T0v0f0x1m0#0%011E1G1I1G0k1O1Q1M0k0q1b1A0Y0}0g0M0w0E0(0j011S1o010m0V0x0E0w0O0x1M1.1:1^1U1{1Q1~200-0a0J0y0q0D0M0D0g0r100E0J0R1,0q0q0x0K2l13230E1b0b1A2y1(1*1)1N0d251p0r0E1}2i1M1j1l0Z1T2I2K0E0D2O1M0M2r1b2w2y2#0:1/2m2Q1_2U0q0@0f1M0w1D2r0m0(030l0l0K2V0x1I2T0D0n0F0P0n0P0-0P130w2$2)0.2(242+1U2-2/2;2?0x2^012`2|2~302L33351?040j3a3c1:3e2w2H013j0w2:1b2=0G2@2_2{2}0R3t2U3v0n0h0-0h3A2v3d0/3E3h0(3H3J053L3N3p3P3s2J3u34330-0F3Z143#3f2*1n3i0D2.3I3l3M3n3O3r3R3=3T3@0t0-0t3{2#3$2)3F3*453.3q3Q2 4b323@0I0-0I4h3d1e2Z132O2B0d1*2G3(014q2N1k1b2Y0x2!4z3|3C054q4Q240r0d0(2{2w3U373K0J4Y4!494r314%1@290x4,4q3S4t354(3Z3%400(0H0-0R0m3!3C0J3~4l0m0-0g1:0g0l0d0D0A1P11552x584I0,040e5l4W3 2R3G0-1#0x0w0A5s5n4 015p0B0z5s0/4S5m3E4+014#2)3U3x3,4*4Z5P4-4_5S4;1 4?5X4^4s5!2y3b0J5.574~5v0E0-2U0A0i5z5B5L045:4k4I0D0-0c5s5 3g5E5p0u0N5J5C5N5W5Q1:3U3W4)5O3:4a4/3@3W0J4=4@3;6o356j3A5/665u1_51040m42655D5=5@0D0O0v2r6H5;1_0D0L0-2J6P605E5?045y5A6d6X5v5p5I5}5K2%6e4,4$3@0F3l6l5Y5*6=5#206t6n3?356?5,5~6z5/6I6C6U545}6A4l6K6M6O7b771U6S6K0k6W675v7k046V7h6Q3i6K5_5{6%7o1_6*6c5}586^6;354e6k6f6_6v0n4e6r5$6~4.707O1M0b5-757Z7i3)7w5`6$7E7u0(62040p7z6B7v040w0M0M1}0d7:3F5p5r7*6(2,7e6N0x7|5o0-0B7D6.4k7G5R4u6@7L5)7N4v7Q6}5(6u7U4v736z7#016D2r0k0A0q127t817=5^7(5|4i5C0b4V4A4P4C4M130k4F8P2E2z0w1P8M0b4D5K0R0T0V0g04.

Exercice 4 : Savoir compter⚓︎

Écrire une fonction compter_triples qui prend en paramètre une liste entiers de nombres entiers et renvoie le nombre de multiples de 3 de cette liste

Attention

Il est interdit d'utiliser count

Compléter le code ci-dessous

###(Dés-)Active le code après la ligne # Tests (insensible à la casse)
(Ctrl+I)
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/=d(%l+s30v2t_f-Srig5baeP:u)yon4hk6 cwpm1050d0y0n0x0t0g0i0K0L0g0x0i0i0c010n0t0N010406050i0B0O0O0x0s0D040r0E0g0B0*0E0F050b0;0?0^0`0/0N04051a131d0b1a0/0d0t0l0Y0!0$0(0!0F0u0B0x0u0y0q0N0D0n0H110K0H0t0u0H0g1F0H0n0-050T0w0g0y1m0#0%011E1G1I1G0n1O1Q1M0n0s1b1A0Y0}0i0N0x0F0(0m011S1o010p0V0y0F0x0O0y1M1.1:1^1U1{1Q1~200-0a0K0z0s0E0N0E0i0t100F0K0R1,0s0s0y0L2l13230F1b0b1A2y1(1*1)1N0d251p0t0F1}2i1M1j1l0Z1T2I2K0F0E2O1M0N2r1b2w2y2#0:1/2m2Q1_2U0s0@0g1M0x1D2r0p0(030o0o0L2V0y1I2T0E0q0G0m0q0P0-0P130x2$2)0.2(242+1U2-2/2;2?0y2^012`2|2~302L33351?040m3a3c1:3e2w2H013j0x2:1b2=0H2@2_2{2}0R3t2U3v0q0j0-0j3A2v3d0/3E3h0(3H3J053L3N3p3P3s2J3u34330-0G3Z143#3f2*1n3i0E2.3I3l3M3n3O3r3R3=3T3@0v0-0v3{2#3$2)3F3*453.3q3Q2 4b323@0J0-0J4h3d1e2Z132O2B0d1*2G3(014q2N1k1b2Y0y2!4z3|3C054q4Q240t0d0(2{2w3U373K0K4Y4!494r314%1@290y4,4q3S4t354(3Z3%400(0I0-0R0p3!3C0K3~4l0p0-2}0O0N0n0y0s0o1(0+1Q0i552x584I0,040e5n4W3 2R3G0-1}0*5g5m4S5o4~5x5r0C0A5u0/5E5v4*4Z014#2)3U3x3,5P4@3;4/3@1?0K4=5Y4a5!3w1M0b3b0K5:575G2,5b5e5u5=4k4I0E0-0c5`5p4 010O0t0-0k5L5u584+5R0o4$3@3W4)6c3:5*3?353W5%1 4?6d4^4s3U6h3A5;5{3g6351040p42615?3i0-2U0O0w2r6G5|630E0M0-2J6O6A5x0F5z0F5B0s5D2%6H0(5r5K5N5M6(4k6j6e5T3@0G3l6;6t5+3^6p205)4.6m3^2y5/6y5;625x6C0t545N6z5w5@046K6M0y6V7f1U5~040f7l3F653X7r5}5 607d781_7t04685N7A1U6+697F3E6;6f354e6i5Q6k714c7O4;6q704_3U7P6x767%7G3)5^0n7v6Q5 7-6X7+7:1_7o0h7?1U7C396-6a7L7R6=1:3U4v7Q7Y6u4u7W6 6s5Z72857$5:7)016C2r0n0B0s127z6)5y040L5_7~7F0b4V4A4P4C4M130n4F8E2E2z0x1P8B0b4D5M0R0T0V0i04.

Exercice 5 :⚓︎

Indice du minimum

Exercice 6 :⚓︎

Maximum

Exercice 7 :⚓︎

Distribution de costumes

Exercice 8 :⚓︎

Aplatir un tableau

Exercice 9 : Le nombre mystère⚓︎

Trouvez le nombre mystère qui répond aux conditions suivantes :

  • Il est composé de 3 chiffres.
  • Il est strictement inférieur à 300.
  • Il est pair.
  • Deux de ses chiffres sont identiques.
  • La somme de ses chiffres est égale à 7.

On vous propose d'employer une méthode dite de « force brute », c'est-à-dire de tester tous les nombres possibles répondants aux trois premières conditions.

Question

Compléter le script suivant

  • possibles est la liste des nombres répondant aux trois premiers critères.
  • liste est la liste des nombres répondant au problème.

###(Dés-)Active le code après la ligne # Tests (insensible à la casse)
(Ctrl+I)
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/;=d(%l+s3x0v29Ft_f,-SErig85T[7baeP:u)yonq4hk6 cwp]m1050e0I0r0H0z0h0j0V0W0h0H0j0j0d010r0z0Y010406050j0L0!0!0H0y0N040w0O0h0L0_0O0P050b101214160~0Y04051m1f1p0b1m0~0e0z0n0.0:0=0@0:0P0A0L0H0A0I0v0Y0N0r0S1d0V0S0z0A0S0h1R0S0r0|050)0G0h0I1y0;0?011Q1S1U1S0r1!1$1Y0r0y1n1M0.190j0Y0H0P0@0o011(1A010t0+0I0P0H0!0I1Y1}1 241*271$2a2c0|0a0V0J0y0O0Y0O0j0z1c0P0V0%1{0y0y0I0W2x1f2f0P1n0b1M2K1@1_1^1Z0e2h1B0z0P292u1Y1v1x0/1)2U2W0P0O2!1Y0Y2D1n2I2K2;0 1~2y2$252*0y130h1Y0H1P2D0t0@030s0s0W2+0I1U2)0O0v0R0k0v0#0|0V0#1f0H2=2^0}2@2g2`1*2|2~30320I340136383a3c2X3f3h22040V0o3n3p1 3r2I2T013w0H2 1n310S333537390%3G2*3I0v0k3k0k3O2H3q0~3S3u0@3V3X053Z3#3C3%3F2V3H3g3f3k0R3;1g3?3s2_1z3v0O2}3W3y3!3A3$3E3)433+450C3k0C492;3@2^3T3{4j3 3D3(3b4p3e450U3k0U4v4b3^4e3`4g3x3Y3z3B4D423d3,0F3k0F4M3Q4x3t4P3U4R4i4T4k4V414o4Y450B3k0B4%2J4)4d2%4,4h3|3~4l404n4F4@3h0p3k0p4|3R4y3_514S3}4U4m4E3*4H3h0#0m0|5r5e4~4z4-535l565n4G3,0#3j045F5v4c5x524B554W4?445q3K0#3N0b3o3=4(5K5h4A4/4C4=585R3i3.5H3:5W3P4}5!4+5$5k4:5m4X5+0#0R5t485:5Y5=4O505^544;575o5E4s5H4u624a5Z652{5y5N695C593i4J5H4L6g4w5?666l5%5O5)6b450#4!5H4$6u4N5g5@6y5_5(6a5D6D4_5H4{6I6i6K6x5M6z6n5|4q5q5b5H5d6V646X6k6Z6N6A6P6p0o5s046^5J6j4f6:685{5Q6%0v0o5G756|6.6~5j705B6$5p743K0o5V5X6h6-4*6Y7b5A5P5*730o5-7u787n6/7p5`7d727f0o5 6`617k6v6}4Q6 7q6B6Q3J6d0o6f7J6J7y7a4.6;6#7D3,0o6r7(7x4 7z7Z7c7r6C3J6F0o6H7V6W7X7M7A6O6o5+0o6S817+5L7}6=7 7t6)0o6+7_7m7,7Y5z7B7:7Q3-6_0k0m845#6M7/7P6p0k5G8v8p6L7N8i8t5+0k3K8E8y7o7.7O6?8D5-0k5/8d2K2.0I2K2!2N0e1_2S5h4E2Z1w1n8S2:3q631n4E8*2g0z0e0@372I5E3y8;8?8L733j0V2l0I8|887f5G3;7L010T0|0%0t8,0V6w2{0t9b0I0L0l381Q0t0t0I0j0s8;290r8,9g1*0{040f9x980P0|0P0G2D9D790@9A0K9K7{3U0G0|2V9w7l8/8f9M0|0M9P9Y010O0|0v020A0r0c9e9y3`9S040G0O199$3T9N8,0~9W5K8{018@2^7%8`8=a38}7E2391937ea62K5X980X3k0Vam9{5h0j0e0|020Q0L0O9.atavaxauaw9/9W9 2?3Sa2a41 3,5-5kaIaaaLac2b92a994aQah9X3Taqalam2D0P0n0O0z1%0D0y0L1%2v909I1%310%9l0.9o0t2D0-9u0P0_au9r0u0V0q3W0ja:2V1d9~9{aO8^457GaNa88C735 90aSae7$bh1Y6298a!3Lam0V0x0l0I0!0Y1$0-9OaEbebk0sbg3h6dbjbq7s7f4sbo2cbQ7;0vbObu9L01bwby0V9,ax9-0cb*0c2z9k9m0Wa|9r9t0%b10f5U0#9#bIa0aHbKbM0v6rbPaUaf4IaRbVc8br3hc6b!9Qb%bya-a/bdc14ybfa5456Fc7bl7f4!bUaTcv4Zbtaib#cjamb.cHb,b:9l9n0z9pb^b00rb|7ub 6vco8:c3cr3h6ScuaP4^cbczc%c!cCaYaparbxamb70,0IcnaGcpcYaK456)c$aVc~c)bW8kc 5:aF8+c28|c45ra7d46pddcydf5}6_3Od83Qa1c|0P5E9631aOd15q8 adcdbRdsc-9;b$c:b(ayaCdIaAazaDcVc`cXdbcZ3i3Kd0c95Sd3dAbX5Uc-b(dE9F040!aw9:989)040dd-b#9H0|0j1@ao4+9A9CcW9%d)9H9Jd 9|9!c_d9c{dRc}5qaMdubKdw5,dYcA6DaM5:d%989a04cNd=9Qd}d{660|d+9VdP9%9A0Eev250!0z0|8oe45h9A0Zes9%d/0dd;9W9f9Eexd,eKd|0|eDeY50eG5teE9z0|eNeTdE0Oak044geO4zeWeze8ete!e*0@e(5He~01eMe@5heQeS2;eUd?e_f2eCf2f05VeAe5040ZcU3qfa9Qe:0|e?eTfoe0fce$25fefx1*f0eJfieLe,f54+f7fHewd*eXfEeZ04e#fOe%eH6`fde,bHdOe{2ycqeb3ibieedj8~bndzej5qbiemb(bydEep2D0r0L0y1ee.eo0W0|clc^c0fif$dr6DbOf*dZ8k0#bTf.c+3ibZ3oenb#ep3bb9fW04fY4be4g75Ec6gbf/6qeigh0#cggkf?aneo0|f`f|f~f9f^g104c?gpg5f!0Vgv6DctgygCcxggeg6Ec-dn2Jdpeag85qc#gZg%4_digcdgc#ch9%ep9cfK9hd^0O120IcM9pa~gqd~fS2{9Ga?gqgsdo9E9?9Ugqfmhgb#d/9+b,f2d@eqb1hee7hmdQa9dcc g;dW3i5bg@gz0#d6cD9Qe;d%fA0@bwdKb-aBdLaChwg+dahzdS6^deg^805shGghh#aXdEcF0Va%a)a+0V0:0V0jh22cb:0-b?cN9q0-2Ae2g4fZhxf#dq7%dtgVefhD75gBegifh-bvdGbybAbCbE1%hf5=gui9457ih$gziwh*ihdUg{aZilcGb,cI9.h_h{h4h h69rcS0khlisg6iu3Jedicf+7E3.iAieelhK9%h/6ti6hXe9hZf%7Fixh+f-bph%7tf;3og*aYgW7Ri?ihgfi_iygjc.4+h/hRjbhTdNgtiUg-7%gxiYi`7E4Ji$ce74gEc;fue^fMe`3Qjtf60|f8fnd(9?d_0yh8hrhce3hae+04iS3ritjhivgYjkiyg#j5h+ctf=gHfb04h`h3g 1*eQj*e fUfDjfgUj074g:jUh+g?g$ieg`gFj#9Qep0tfsgNeV040W14j-9(e;2Vkad)eyhvgTi7j_c48bj2iehFj|jpkmaXgGk0fvj%iLkaj,f j$j(2ckz0|0ikehihuhOf30|h9gU5#0|k8jGkL9AjOi~g,i:g.8lknjp8nighDk(ktf@gI04gKf}keh1j)kii.hyaJk!8vk$dB45k}jok 3hk}aXkXhYk{aLdUhCk%22l2bX8EdDk62t0=0z1#9rkFd:kafzjL3`9Tkak2k4jCk60zkzkcgMlzd?9?0y1 1HjHkLf05rj:kjfF040ukaf08nlPk_eBe6kBk19T9dl#kwlBl)3Td/0glUfUfhlFfpjAjBlQ4+fCgqe-i-i iV3-iXdvk*i#kql3m2lij$1Ud_i5l?ePjAlre}kLe1hdl,5hlxkTk5j$i4lC9TlEjxd(0|lk2vln0jlwl%mi9BjI04a_b=b@9scQlLlt3UjJmel`50kVlpeRlwgPg3mu041 0ek=kxh3h5a}lokUkNmImtm:jNmXl_2Jjyl{fU6HmQkVl~j;do0b8.1q2/1f8V1f0r8Xnb2Q2L0Hln8U8%9 0%0)0+0j04.

III. Les chaines de caractères⚓︎

Renverser une chaîne

IV. Les dictionnaires⚓︎

Question

Compléter le script suivant pour qu'il affiche la liste pokemons_rapides des noms des pokémons dont la vitesse est supérieure à 60.
On doit obtenir l'affichage : ['Salameche', 'Reptencil'] ou ['Reptencil', 'Salameche']

###(Dés-)Active le code après la ligne # Tests (insensible à la casse)
(Ctrl+I)
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

Solution 1

Correction possible utilisant la méthode items:

Python
pokemon1 = {'Nom' : 'Carapuce', 'HP' : 44, 'Attaque' : 48, 'Defense' : 65, 'Vitesse' : 43, 'Type' : ['Eau']}
pokemon2 = {'Nom' : 'Evoli', 'HP' : 55, 'Attaque' : 55, 'Defense' : 50, 'Vitesse' : 55, 'Type' : ['Normal']}
pokemon3 = {'Nom' : 'Salameche', 'HP' : 39, 'Attaque' : 52, 'Defense' : 43, 'Vitesse' : 65, 'Type' : ['Feu']}
pokemon4 = {'Nom' : 'Reptencil', 'HP' : 58, 'Attaque' : 64, 'Defense' : 58, 'Vitesse' : 80, 'Type' : ['Eau']}
liste_pokemon = [pokemon1, pokemon2, pokemon3, pokemon4]
pokemons_rapides = []
for pokemon in liste_pokemon:
    for cle, valeur in pokemon.items():
        if cle == 'Vitesse':
            if valeur > 60 :
                pokemons_rapides.append(pokemon['Nom'])
print(pokemons_rapides)
Solution 2

Correction possible sans utiliser la méthode items:

Python
pokemon1 = {'Nom' : 'Carapuce', 'HP' : 44, 'Attaque' : 48, 'Defense' : 65, 'Vitesse' : 43, 'Type' : ['Eau']}
pokemon2 = {'Nom' : 'Evoli', 'HP' : 55, 'Attaque' : 55, 'Defense' : 50, 'Vitesse' : 55, 'Type' : ['Normal']}
pokemon3 = {'Nom' : 'Salameche', 'HP' : 39, 'Attaque' : 52, 'Defense' : 43, 'Vitesse' : 65, 'Type' : ['Feu']}
pokemon4 = {'Nom' : 'Reptencil', 'HP' : 58, 'Attaque' : 64, 'Defense' : 58, 'Vitesse' : 80, 'Type' : ['Eau']}
liste_pokemon = [pokemon1, pokemon2, pokemon3, pokemon4]
pokemons_rapides = []
for pokemon in liste_pokemon:
    if pokemon['Vitesse'] > 60:
        pokemons_rapides.append(pokemon['Nom'])
print(pokemons_rapides)
Solution 3

😀 : Solution beaucoup plus élégante avec une liste en compréhension :

Python
pokemon1 = {'Nom' : 'Carapuce', 'HP' : 44, 'Attaque' : 48, 'Defense' : 65, 'Vitesse' : 43, 'Type' : ['Eau']}
pokemon2 = {'Nom' : 'Evoli', 'HP' : 55, 'Attaque' : 55, 'Defense' : 50, 'Vitesse' : 55, 'Type' : ['Normal']}
pokemon3 = {'Nom' : 'Salameche', 'HP' : 39, 'Attaque' : 52, 'Defense' : 43, 'Vitesse' : 65, 'Type' : ['Feu']}
pokemon4  ={'Nom' : 'Reptencil', 'HP' : 58, 'Attaque' : 64, 'Defense' : 58, 'Vitesse' : 80, 'Type' : ['Eau']}
liste_pokemon = [pokemon1, pokemon2, pokemon3, pokemon4]
pokemons_rapides = [pokemon["Nom"] for pokemon in liste_pokemon if pokemon["Vitesse"] > 60]
print(pokemons_rapides)