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

.128013w]itkc[vN8o-)yl0bp_P3(a;+g=/m4rse97Sf,d 612:5nuh050N0H0e0x0d0p0G0O0g0p0x0G0G0B010e0d0s010406050G0V0D0D0x0F0o040K0l0p0V0;0l0U050C0{0}0 110_0s04051h1a1k0C1h0_0N0d0i0)0+0-0/0+0U0A0V0x0A0H0m0s0o0e0W180O0W0d0A0W0p1M0W0e0@050!0r0p0H1t0,0.011L1N1P1N0e1V1X1T0e0F1i1H0)140G0s0x0U0/0R011Z1v010L0$0H0U0x0D0H1T1^1`1 1#221X25270@0a0O0u0F0l0s0l0G0d170U0O0Y1?0F0F0H0g2s1a2a0U1i0C1H2F1/1;1:1U0N2c1w0d0U242p1T1q1s0*1!2P2R0U0l2V1T0s2y1i2D2F2,0`1_2t2X202#0F0~0p1T0x1K2y0L0/030t0t0g2$0H1P2!0l0m0R0m0Q0@0O0Q1a0x2-2:0^2/2b2=1#2@2_2{2}0H2 01313335372S3a3a3e0R3h3j1`3l2D2O013q0x2`1i2|0W2~3032340Y3A2#3C0v3e0v3G2C3k0_3K3o0/3N3P053R3T3w3V3z2Q3B3b0E3e0E3(1b3*3m2;1u3p0l2^3O3s3S3u3U3y3X3`3Z3b0T3e0T402,3+2:3L3/4a3?3x3W364g393b0P3e0P4m423,453.473r3Q3t3v4u3_383C0J3e0J4D3I4o3n4G3M4I494K4b4M3^4f4P3b0k3e0k4U2E4W442Y4Z483:3=4c3@4e4w4+0m0I3e0I4:3J4p3-4^4J3;4L4d4v3Y4y3c0q0@0Q0q554=4q4!4`5c4}5e4x3C0Q3d045w5m435o4_4s4|4N4*3{3c1}5y3F0C3i3)4V5B584r4$4t4)4 5I0Q3#5y3%5N3H4;5R4Y5T5b4%5d4O5Y3}5y3 5%5P2E1l2*1a2V2I0N1;2N584v2U1r1i2)0H2+3k5_1i4v6a2b0d0N0/322D5v3s6h6j4~5f6m0O2g0H6p5t505x3(4F4@0f0@0Y0L6c5*4@0b3e6H6B2?0L0@2Q1q0g0H0t2y0g0V0F2q0i0H6M574Y0?040w6%4X4@0U0@0i3O0H6Y0G6-4?206*0M6c0O6I2?0@0g0d1W6$413I711#6}6 7a3.6E0H0r166`3L7c782E706N3p0@22197n6f6{7b0@0n0S6c0_7v5B6o016k2:3C5K5b7G5W6r3b1}6t266v7H6q5u7Q1T5%0O7#7p6(6C6Q6G7v7%6.72040Y7i0e7d7q0/0l0@020A0e0y7@7(7/7t7k586*7B7v7D2.3K7N0t6l3b5!7M6i7V6x5I3#7S276w5:4h0m8g7!7$8v7e016D042y0e6Y7u2,7-7x0/0f0g0@0j18774n7k8c8e0m5=8h8p5H8r3}8n7U7O7X8T7Z3i8w7^3M0@0D0$0d6@807.1#7`040B8?8H016*6,7E8,6:7:7h7j7,8x8_0z8|4q7s2Q846)7z9b588_0C0C9i4Y8/0@5M8P914p8R7J4i6n8i8$504j8!8W5X8r4j2F8*7$8x8z0d7+8F8x936=1X6^9f4@6*0h9V7/8/1P8=9t8@0/6*0c9n4@8_7|7~9-7/74769Z7y04879s8a9u9z8d9w0m4A4K8c8k8r4A9D8j8q5ga43G8v8+811#8z8B8D9=7r046R0d6T6V2z6^1r8O6b8,8 9_7f049S6@6ZaB8~0@6~979273751XaH7m9PaM947=aQaJanaC9#8;0VaY018_0ma%9p5yaW040n7C8Qa08S4Ra5a0a75g4Raa9A5Ia^af9K8,8z4w9O3k8G9caD6?9U9(8}9XaH93a!9%9~9)aI049,aLai7_7{0p9;bqbm939@aPbe7l0@9|42bB9v1`3C4-a_9E7P0m4-a~7W50bKb2agb958ak0Zambw8}93aqas6Wav6#a.90blb$6;bcaGbB85aXb#babzax79azb_aSbr8-04bja$b`9j0@9ac79o0d5ja.aKc1bx9d8Eayc26*a:88a=6p8S52bLab8X5g52bQa{3CctbUbW4Yb50%b}5`b 9{a;bGa?a25k9ybM8%cQczac5v5i9I04bV7#9L0@al0Fck3IcE6/8.8:bkbFb/0ObH0U5v6z2|a6cW3b5w1~6ucS6y6z5%89cl6gcObIc 7Lc|a`c~5Jd17Td35Y7Ld6cq7V8S5ZcRcv9F5gdrcVcw5v8t5Ob47gb7b~c26Kc!bh6Pap0U6ScI7wbC6+bhb;9Tb?c?b^04cgb89QaN9^b@9ga/bE5QcNcrcP8Udedk8r0Q8Zd2dtbNd@8)c!b3c2bY8Cc*a%b%dMar6Ub*6Zawb-dSbbdU6_d(9Wc0d!aTb|cfa+cd045leh6|ejc,9Q0r0@2fecesaoaEbddWd)coch8}a)eoceeB9*9hcp7E0C6e5{695}661a0e60eY2L2G0x762F5~7D0Y0!0$0G04.