Aller au contenu

Rechercher un élément dans un tableau trié⚓︎

L'objectif de cet exercice est d'écrire une fonction indice

  • qui prend en argument :
    • un tableau valeurs rangé dans l'ordre croissant
    • une valeur cible
  • qui renvoie :
    • l'indice de cible dans le tableau s'il en fait partie
    • None sinon

La fonction indice utilisera une fonction indice_recursive qui sera récursive et qui prendra les mêmes arguments que indice, et en plus debut et fin qui désigneront les indices pour la recherche : de debut inclus à fin inclus.

Le tableau valeurs pourra être rempli d'entiers ou rempli de chaines de caractères, sans aucun changement à procéder ; en effet ce sont des éléments comparables entre eux, ordre naturel pour les entiers, ordre lexicographique pour les chaines de caractères.

Exemples

Python Console Session
>>> nombres = [2, 3, 5, 7, 11, 13, 17]
>>> indice(nombres, 7)
3
>>> indice(nombres, 8) is None
True
Python Console Session
>>> fruits = ["abricot", "kiwi", "mangue", "poire", "pomme"]
>>> fruits == sorted(fruits)  # le tableau est bien trié
True
>>> indice(fruits, "kiwi")
1
>>> indice(fruits, "cerise") is None
True
Compléter le code ci-dessous

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

.128013b];=wlSd[f-:431(gnahp/+uerovm)6 72i,y9c8s_PNtk05050i0z0T0t0J0g0P0G0N0g0t0P0P0e010T0J0v010406050P0y0D0D0t0A0L040h0B0g0y0;0B0s050w0{0}0 110_0v04051h1a1k0w1h0_0i0J0C0)0+0-0/0+0s0r0y0t0r0z0l0v0L0T0u180G0u0J0r0u0g1M0u0T0@050!0b0g0z1t0,0.011L1N1P1N0T1V1X1T0T0A1i1H0)140P0v0t0s0/0I011Z1v010k0$0z0s0t0D0z1T1^1`1 1#221X25270@0a0G0R0A0B0v0B0P0J170s0G0Y1?0A0A0z0N2s1a2a0s1i0w1H2F1/1;1:1U0i2c1w0J0s242p1T1q1s0*1!2P2R0s0B2V1T0v2y1i2D2F2,0`1_2t2X202#0A0~0g1T0t1K2y0k0/030Q0Q0N2$0z1P2!0B0l0I0l0p0@0G0p1a0t2-2:0^2/2b2=1#2@2_2{2}0z2 01313335372S3a3a3e0I3h3j1`3l2D2O013q0t2`1i2|0u2~3032340Y3A2#3C0o3e0o3G2C3k0_3K3o0/3N3P053R3T3w3V3z2Q3B3b0n3e0n3(1b3*3m2;1u3p0B2^3O3s3S3u3U3y3X3`3Z3b0W3e0W402,3+2:3L3/4a3?3x3W364g393b0F3e0F4m423,453.473r3Q3t3v4u3_383C0H3e0H4D3I4o3n4G3M4I494K4b4M3^4f4P3b0O3e0O4U2E4W442Y4Z483:3=4c3@4e4w4+0l0M3e0M4:3J4p3-4^4J3;4L4d4v3Y4y3c0V0@0p0V554=4q4!4`5c4}5e4x3C0p3d045w5m435o4_4s4|4N4*3{3c1}5y3F0w3i3)4V5B584r4$4t4)4 5I0p3#5y3%5N3H4;5R4Y5T5b4%5d4O5Y3}5y3 5%5P2E1l2*1a2V2I0i1;2N584v2U1r1i2)0z2+3k5_1i4v6a2b0J0i0/322D5v3s6h6j4~5f6m0G2g0z6p5t505x3(4F4@0U0@0Y0k6c5*4@0f3e6H6B2?0k0@2Q1q0N0z0Q2y0N0y0A2q0C0z6M574Y0?040q6%4X4@0s0@0C3O0z6Y0P6-4?206*0K6c0G6I2?0@0N0J1W6$413I711#6}6 7a3.6E0z0b166`3L7c782E706N3p0@22197n6f6{7b0@0E0m6c0_7v5B6o016k2:3C5K5b7G5W6r3b1}6t266v7H6q5u7Q1T5%0G7#7p6(6C6Q6G7v7%6.72040Y7i0T7d7q0/0B0@020r0T0d7@7(7/7t7k586*7B7v7D2.3K7N0Q6l3b5!7M6i7V6x5I3#7S276w5:4h0l8g7!7$8v7e016D042y0T6Y7u2,7-7x0/0U0N0@0S18774n7k8c8e0l5=8h8p5H8r3}8n7U7O7X8T7Z3i8w7^3M0@0D0$0J6@807.1#7`040e8?8H016*6,7E8,6:7:7h7j7,8x8_0x8|4q7s2Q846)7z9b588_0w0w9i4Y8/0@5M8P914p8R7J4i6n8i8$504j8!8W5X8r4j2F8*7$8x8z0J7+8F8x936=1X6^9f4@6*0j9V7/8/1P8=9t8@0/6*0c9n4@8_7|7~9-7/74769Z7y04879s8a9u9z8d9w0l4A4K8c8k8r4A9D8j8q5ga43G8v8+811#8z8B8D9=7r046R0J6T6V2z6^1r8O6b8,8 9_7f049S6@6ZaB8~0@6~979273751XaH7m9PaM947=aQaJanaC9#8;0yaY018_0la%9p5yaW040E7C8Qa08S4Ra5a0a75g4Raa9A5Ia^af9K8,8z4w9O3k8G9caD6?9U9(8}9XaH93a!9%9~9)aI049,aLai7_7{0g9;bqbm939@aPbe7l0@9|42bB9v1`3C4-a_9E7P0l4-a~7W50bKb2agb958ak0Zambw8}93aqas6Wav6#a.90blb$6;bcaGbB85aXb#babzax79azb_aSbr8-04bja$b`9j0@9ac79o0J5ja.aKc1bx9d8Eayc26*a:88a=6p8S52bLab8X5g52bQa{3CctbUbW4Yb50%b}5`b 9{a;bGa?a25k9ybM8%cQczac5v5i9I04bV7#9L0@al0Ack3IcE6/8.8:bkbFb/0GbH0s5v6z2|a6cW3b5w1~6ucS6y6z5%89cl6gcObIc 7Lc|a`c~5Jd17Td35Y7Ld6cq7V8S5ZcRcv9F5gdrcVcw5v8t5Ob47gb7b~c26Kc!bh6Pap0s6ScI7wbC6+bhb;9Tb?c?b^04cgb89QaN9^b@9ga/bE5QcNcrcP8Udedk8r0p8Zd2dtbNd@8)c!b3c2bY8Cc*a%b%dMar6Ub*6Zawb-dSbbdU6_d(9Wc0d!aTb|cfa+cd045leh6|ejc,9Q0b0@2fecesaoaEbddWd)coch8}a)eoceeB9*9hcp7E0w6e5{695}661a0T60eY2L2G0t762F5~7D0Y0!0$0P04.