Les deux meilleurs

Vous venez de développer Flap Flap Bird, un jeu très dur où il faut aider un oiseau à éviter des obstacles. À la fin de la partie, vous enregistrez le score du joueur et vous souhaitez afficher ses deux meilleurs scores. Ceux-ci peuvent être égaux.

On considère les deux listes de scores suivants :

  • scores_1 = [13, 15, 12, 3, 19, 7, 14]

  • scores_2 = [27, 35, 14, 35, 3, 26, 9]

Pour score_1, les deux meilleurs scores sont 19 et 15. Pour score_2, ce sont 35 et 35.

Il est possible que la liste de score contienne moins de deux valeurs. Dans ce cas, les meilleures valeurs sont remplacées par None.

Compléter le code de la fonction deux_meilleurs qui prend une liste d'entiers scores et renvoie :

  • le couple formé par les deux meilleures valeurs max1 et max2 avec max1max2 si la liste contient au moins deux scores ;

  • le couple (max1, None)max1 est le score maximal si la liste ne contient qu'un seul score ;

  • le couple (None, None) si la liste est vide.

Contraintes

On n'utilisera ni max, ni min, ni sort, ni sorted.

Aide

Il s'agit d'une recherche de maximum originale car on cherche les deux valeurs maximales.

On pourra débuter l'algorithme en affectant la valeur None aux variables max1 et max2 puis en parcourant les scores. Pour chacun d'entre eux on mettra à jour, si besoin, l'une des variables (ou les deux).

La question principale est donc de savoir quand mettre à jour max1, max2 et les deux ?

La valeur None

None est une valeur spéciale utilisée en Python et qui correspond à un manque de valeur normale. Lorsque l'exécution d'une fonction se termine sans avoir rencontré un return, Python renvoie automatiquement la valeur None.

On peut tester si une variable x contient la valeur None de la manière suivante :

🐍 Script Python
if x is None:
    ...
On pourrait également tester x == None mais si x est un objet d'une classe dans laquelle l'égalité a été redéfinie, l'égalité peut être vraie, alors que x is None ne l'est pas.

Exemples
>>> scores_1 = [13, 15, 12, 3, 19, 7, 14]
>>> deux_meilleurs(score_1)
(19, 15)
>>> scores_2 = [27, 35, 14, 35, 3, 26, 9]
>>> deux_meilleurs(score_2)
(35, 35)
>>> deux_meilleurs([4, 5])
(5, 4)
>>> deux_meilleurs([5, 4])
(5, 4)
>>> deux_meilleurs([5, 5])
(5, 5)
>>> deux_meilleurs([9])
(9, None)
>>> deux_meilleurs([])
(None, None)

###(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

.12801356/dmsyaoqP[(nk,bgp3v4;cu_IwNh)8xr]R:tl =i7S1ç9fe02050e0X0M0i0Q0N0g0O0y0N0i0g0g0P010M0Q0t010406050g0z0f0f0i0I0h040S0j0N0z0@0j0o0O020i0f0t0x0O0K0X110I0k0z0X0g050d0~1012140|0t04051z1s1C0d1z0|0e0Q0v0,0.0:0=0E0Q0s0E0N1Q0E0M0`050%0r0N0X1L0/0;011P1R1T1R0M1Z1#1X0M0I1A0M0E0,170g0t0i0o0=0Z011%1N010W0)0X0o1f0X1X1}1 241)271#2a0f2c040a0O0l0I0j0t0j0g0Q1a1c0#1{0I0I0X0y2x1s2e0o1A0d1_2J1?1^1@1Y0e2g0=1T0o292u1X1I1K0-1(2T0Q2V0o0j2Z1X0t2C1A2H2J2;0}1~1c2#252*0I110N0`0O0T2G2^0{2@2f2`1)2|2~300Z331 352H2S013a0i2 040O0u3e2I0|3h380=3k3m0O0w3q3g2^3i3w300b3A3s3C3u3j0j2}3l300c3H362_1M393M3b3n0R3R3t3U3v3W3O3n0G3!3J3$3L3N3x0V3,373.3E040T0Y3A1D2/1s2Z2M0e1^2R3K0y2+2m0!1J1A2.0X2:343}470#4f3@2$010p0`0#0W3}3#4m0C304s3-4m0o0W4p0X0z0H0A2l0)1#0z0I1r1t4g4t250_040n4x4l2{0`0g472C4M2?4P1)4R0F0L3H0O4-0O3S3D0`110H324N3f4/4%0=0j0`0P3A4{4y250p0y0`0D1b0X4,4.4:3K0o4=0i0H3d4_2I524V1)4~04505k3n5d3.5557595b4-5u4m4o040W3M515B4W040v5H4|010j4v042(5M53394X4Z1q4U3T4m4R4+5s064.5*5m5!540`0Q4r5s5,4;044?4^2;5?3K5P5/4#345|5v5604582V5T5n4}5Q5G5=5I5V5K685-5o0`020s0M0x6h5@5_5Z3i5$5z5+5*6e3v5g5i6p5}4 6C3^6A5`345)6w5+6y3j6H6F4m5p5r5{6N5f6g5(6L625C0`0X1T5;6U5N6W4?5j6*5U6a5 6Q5464665a6d5N5~046c6/696O6X706i4}6k6m6o6{6:726-6s3K6u6Y6Z5c6+6A6.616N6S6?6f5L7h5A5N5D2C0M4K0o7q6z5^5h6I3f6N4R0q7B7c5h7m3f0|0d4i4e3~7S0d411s0M437X2P2K0i1!7U411y4k75012C0f0A0W0i0p0X0A0E0u0`1k1m1o1q0O5%2?1F351z0B0N0O1q0M0O2t0:0Q7(0O2z7=0Q2C0O0z2V0O7=0U1b8c180+2.0j0y0E1$0e008n1$2C8y0X0I8G8h1$4?0Q0f0 2g0Q7 0q0O0g1 0+0M8a8H4/7R655y7Q483n5%1G4a2!3.1+1S1U1W7,3i2i292b0`2o0S0y0I0^8b0l0h1_1b3}4d7,2=4g8$6N5D4q7e3.5Q4/5s6V4B040#4E4G0X4I4D4L9h5#0`4T9l7k044Y3M5Y9A7b4)826J6x7v5/6)7n6+0r0`2j9w4Q9y9U6f9D4!9X0=4)7K6S6T9P7b0f0Q0`3|9G717g2;6K6w9e0`7x7z7K5w8%679;7-7I9~6^8(9@9L7b5D6%5:7K0o9R049Ta26t9Waj5e5W9E607G5N9%7a719)7K9-0`7F2I7H0`9J7O6Z9`049|0I7Aau7-6W9Z9F4$9H0`0m9#01ay049:aR9=0`0J7JaM3i9 6_6vaHada)an9C5XaqaBasaTaVaXaZ4OaS040J9(776naeao9!am3.4RaUb84maXaA8^7fa$aE3raG9B6rbc9V04a(746q7Mb25qb5a=apaVbaa{9.aYbAa$br9+71aOa?bF04bba!7-bebMb17t6!5.046%0g6`bPak04bj0{bl7b6,7EbMbH4`6V7lbv9*b:9BaPa@bgb9a`bo1)bRb 9$bGbxb`bMbOa~71a|bSa-9M5E6 bIaN5/9(5Q5Sa:3^ag0I1 0sb!c9a3alb#3KaX7Na^a b/5l6Vagaicxb}4SaVbKbzc2014)4*6va9715Da/bsa;c6cObBcO6W0Qcccn6Rb379cX6G7D4@bMb(9^7ib;c:cA5t6|6Ec*5Jbna87i7ub+6Pc 6jbwd77CcZcI9xbNcLcjc!a$cS7jaa6$6(c5bLdidfc$dhddbpbTc.c+046lb4da7L6Bdrc?d3d4bJb=dD7pdDcMb7dv4(b~dR7Cc(drdx9KdlcU9{0$9}dOd6dUcP0`cDc|d5c`3R8)4j7T2J7*400$0(0*04.

###(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

.12801356/dmsyaoqP[(nk,bgp3v4;cu_IwNh)8xr]R:tl =i7S1ç9fe02050e0X0M0i0Q0N0g0O0y0N0i0g0g0P010M0Q0t010406050g0z0f0f0i0I0h040S0j0N0z0@0j0o0O020i0f0t0x0O0K0X110I0k0z0X0g050d0~1012140|0t04051z1s1C0d1z0|0e0Q0v0,0.0:0=0E0Q0s0E0N1Q0E0M0`050%0r0N0X1L0/0;011P1R1T1R0M1Z1#1X0M0I1A0M0E0,170g0t0i0o0=0Z011%1N010W0)0X0o1f0X1X1}1 241)271#2a0f2c040a0O0l0I0j0t0j0g0Q1a1c0#1{0I0I0X0y2x1s2e0o1A0d1_2J1?1^1@1Y0e2g0=1T0o292u1X1I1K0-1(2T0Q2V0o0j2Z1X0t2C1A2H2J2;0}1~1c2#252*0I110N0`0T2G2^0{2@2f2`1)2|2~0`0Z321 342H2S01390i2 040u3d2I0|3g370=3j3l0w3o3f2^3h3u0`0b3x3q3z3s3i0j2}3k0`0c3E352_1M383J3a040R3O3r3R3t3T3L040G3X3G3Z3I3K3l0V3x1D2/1s2Z2M0e1^2R3H0y2+2m0!1J1A2.0X2:333:3}0#45363+0p0`0#0W3:3Y2$010C0`0O4h3*4j0o0W4e0X0z0H0A2l0)1#0z0I1r1t464i250_040n4o4b4q0`0g3}2C4D2?4G1)4I0F0L3E0O4!4n4U3t0`110H314E3e4$4p250j0`0P3x4/4M250p0y0`0D1b0X4Z4#3P3A4)0i0H3c4-2I4_3Q4j4=044@5a045c3h4|4~50524!543H4d040W3J4^5r3+0o0`0v5x4%010j4l042(5D4:384O4Q1q4L5d4H0`4Y5i064#5X5k5s0`0Q4g5i5Z5z564+5K4`1)5G5#4S335)4j5m044 2V5-5R5/5H5w5(5y4N045C625E5f020s0M0x5}55044*4,4T5L0=4I5U2;5W5Y6q632{5+6i4F6k014I0q6e3H5A6g57592;5@4;4?6B5*655Q3h6z6L646h5p5Y6s1)5t0X1T5%6H6W4(6E586R4;5H0Q5=4.6%015_5{51676x5:04616$5E6D666~6`0`6a6c6+5M6)6G6w5.6l5T6U6q5q6 5+7a6:686K6_7c3i5B6U6;5t2C0M4B0o776(6T5i6;6Q7o5~7A6F3O0d48443;7M0d3@1s0M3_7R2P2K0i1!7O3@1y4a7G012C0f0A0W0i0p0X0A0E0u0`1k1m1o1q0O6n461F341z0B0N0O1q0M0O2t0:0Q7Y0O2z7,0Q2C0O0z2V0O7,0U1b86180+2.0j0y0E1$0e008h1$2C8s0X0I8A8b1$4*0Q0f0 2g0Q7_0q0O0g1 0+0M848B4n7L5`5o7K3~5j5U1G402!3+1+1S1U1W7$3h2i292b0`2o0S0y0I0^850l0h1_1b3:437$2=468W7t4t6#7b7%5H4n7C6 4s040#4v4x0X4z4u4C6O3H4I4K9f6x6D4P3J5P9u7p4W7|3e6p7h6x5t5$7z3i0r0`2j9q3+9s9P649x4R9S5S040F9K5f0P5h727p0f0Q0`0Y9W4V7e5V7g6I6X0`7v7x9K6?8Y6j9B0`6A7F5l4}8X5|9;535E6Y6!9K0o9M049O9A7%9Rah6f9U9z9~ai0`9Za23H9#9%5?6;9*309.7d049D3p9=98049_0I7yas6Mam6/2I7D0`0maA01ay049-ak9r0`0Ja19(7%9|a66o5XaG9JaL9T5OaO8/aZ04aSaY3+aVaXao6Pa!9!746b6da/6t04aNaT4Ia_a~3HaV6v3eaQ040JaD0{aF7i6)bfaP5E7Ea%6f4*7k5b6;9#ac5N9ya=bhbb9b3ha|b9a!a$awbnb8a`4jbaaTbebJbi7sa90`6Z0g6^bc9Q9:a+7g6;6D7Bb$bQa0bA79b15gb;bOb.9XbFbg5EbTbP9Xa#b^a;bUb|bq6xbIc09/bVa79G7p5t5v0Ib;0Q9!6-aKbt6Cae0I1 0sb#bGa@9tb`1)aVbwa?b%04bL7l9vaeagcyaBcxcvaMc4caaB0F4X7fa89H5#9acG7p9wcPcK6yaRaT6DckcQc(ccco3+69b3b;b-cNb/aCcU6rbnbvb?avcZ7%b,57bpbl9=cVc!6ud0c3bCc5c*5#bU0Jc|9?0=aaa.c:a:dec-bRc-c+dib?75b4dpb6c dsb(339Fd8b+7jdcb578b_c_b{dg5Idwcddl6=9^0$9`dL7H5,dDcEc@7I5V1s971F3=7P410|7P0$0(0*04.