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

.128013r5aSe )sP4_k,(o8-9myibw26u]:1+d70vl;3t[pfNcng=/h050F0f0M0d0v0J0i0g0R0J0d0i0i0U010M0v0O010406050i0A0t0t0d0b0u040e0p0J0A0;0p0S050V0{0}0 110_0O04051h1a1k0V1h0_0F0v0I0)0+0-0/0+0S0T0A0d0T0f0r0O0u0M0W180g0W0v0T0W0J1M0W0M0@050!0w0J0f1t0,0.011L1N1P1N0M1V1X1T0M0b1i1H0)140i0O0d0S0/0y011Z1v010P0$0f0S0d0t0f1T1^1`1 1#221X25270@0a0g0j0b0p0O0p0i0v170S0g0Y1?0b0b0f0R2s1a2a0S1i0V1H2F1/1;1:1U0F2c1w0v0S242p1T1q1s0*1!2P2R0S0p2V1T0O2y1i2D2F2,0`1_2t2X202#0b0~0J1T0d1K2y0P0/030l0l0R2$0f1P2!0p0r0y0r0D0@0g0D1a0d2-2:0^2/2b2=1#2@2_2{2}0f2 01313335372S3a3a3e0y3h3j1`3l2D2O013q0d2`1i2|0W2~3032340Y3A2#3C0L3e0L3G2C3k0_3K3o0/3N3P053R3T3w3V3z2Q3B3b0k3e0k3(1b3*3m2;1u3p0p2^3O3s3S3u3U3y3X3`3Z3b0c3e0c402,3+2:3L3/4a3?3x3W364g393b0z3e0z4m423,453.473r3Q3t3v4u3_383C0G3e0G4D3I4o3n4G3M4I494K4b4M3^4f4P3b0q3e0q4U2E4W442Y4Z483:3=4c3@4e4w4+0r0s3e0s4:3J4p3-4^4J3;4L4d4v3Y4y3c0H0@0D0H554=4q4!4`5c4}5e4x3C0D3d045w5m435o4_4s4|4N4*3{3c1}5y3F0V3i3)4V5B584r4$4t4)4 5I0D3#5y3%5N3H4;5R4Y5T5b4%5d4O5Y3}5y3 5%5P2E1l2*1a2V2I0F1;2N584v2U1r1i2)0f2+3k5_1i4v6a2b0v0F0/322D5v3s6h6j4~5f6m0g2g0f6p5t505x3(4F4@0m0@0Y0P6c5*4@0x3e6H6B2?0P0@2Q1q0R0f0l2y0R0A0b2q0I0f6M574Y0?040o6%4X4@0S0@0I3O0f6Y0i6-4?206*0n6c0g6I2?0@0R0v1W6$413I711#6}6 7a3.6E0f0w166`3L7c782E706N3p0@22197n6f6{7b0@0h0C6c0_7v5B6o016k2:3C5K5b7G5W6r3b1}6t266v7H6q5u7Q1T5%0g7#7p6(6C6Q6G7v7%6.72040Y7i0M7d7q0/0p0@020T0M0K7@7(7/7t7k586*7B7v7D2.3K7N0l6l3b5!7M6i7V6x5I3#7S276w5:4h0r8g7!7$8v7e016D042y0M6Y7u2,7-7x0/0m0R0@0Q18774n7k8c8e0r5=8h8p5H8r3}8n7U7O7X8T7Z3i8w7^3M0@0t0$0v6@807.1#7`040U8?8H016*6,7E8,6:7:7h7j7,8x8_0E8|4q7s2Q846)7z9b588_0V0V9i4Y8/0@5M8P914p8R7J4i6n8i8$504j8!8W5X8r4j2F8*7$8x8z0v7+8F8x936=1X6^9f4@6*0N9V7/8/1P8=9t8@0/6*0B9n4@8_7|7~9-7/74769Z7y04879s8a9u9z8d9w0r4A4K8c8k8r4A9D8j8q5ga43G8v8+811#8z8B8D9=7r046R0v6T6V2z6^1r8O6b8,8 9_7f049S6@6ZaB8~0@6~979273751XaH7m9PaM947=aQaJanaC9#8;0AaY018_0ra%9p5yaW040h7C8Qa08S4Ra5a0a75g4Raa9A5Ia^af9K8,8z4w9O3k8G9caD6?9U9(8}9XaH93a!9%9~9)aI049,aLai7_7{0J9;bqbm939@aPbe7l0@9|42bB9v1`3C4-a_9E7P0r4-a~7W50bKb2agb958ak0Zambw8}93aqas6Wav6#a.90blb$6;bcaGbB85aXb#babzax79azb_aSbr8-04bja$b`9j0@9ac79o0v5ja.aKc1bx9d8Eayc26*a:88a=6p8S52bLab8X5g52bQa{3CctbUbW4Yb50%b}5`b 9{a;bGa?a25k9ybM8%cQczac5v5i9I04bV7#9L0@al0bck3IcE6/8.8:bkbFb/0gbH0S5v6z2|a6cW3b5w1~6ucS6y6z5%89cl6gcObIc 7Lc|a`c~5Jd17Td35Y7Ld6cq7V8S5ZcRcv9F5gdrcVcw5v8t5Ob47gb7b~c26Kc!bh6Pap0S6ScI7wbC6+bhb;9Tb?c?b^04cgb89QaN9^b@9ga/bE5QcNcrcP8Udedk8r0D8Zd2dtbNd@8)c!b3c2bY8Cc*a%b%dMar6Ub*6Zawb-dSbbdU6_d(9Wc0d!aTb|cfa+cd045leh6|ejc,9Q0w0@2fecesaoaEbddWd)coch8}a)eoceeB9*9hcp7E0V6e5{695}661a0M60eY2L2G0d762F5~7D0Y0!0$0i04.