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

.128013fd6nmi74=]3y_ 9pu08ts5[/v1b(P)l;gow-ah:+rS2cekN,050c0T0u0L0g0F0v0o0S0F0L0v0v0j010u0g0q010406050v0r0f0f0L0P0m040Q0I0F0r0;0I0e050y0{0}0 110_0q04051h1a1k0y1h0_0c0g0z0)0+0-0/0+0e0H0r0L0H0T0K0q0m0u0M180o0M0g0H0M0F1M0M0u0@050!0B0F0T1t0,0.011L1N1P1N0u1V1X1T0u0P1i1H0)140v0q0L0e0/0R011Z1v010b0$0T0e0L0f0T1T1^1`1 1#221X25270@0a0o0D0P0I0q0I0v0g170e0o0Y1?0P0P0T0S2s1a2a0e1i0y1H2F1/1;1:1U0c2c1w0g0e242p1T1q1s0*1!2P2R0e0I2V1T0q2y1i2D2F2,0`1_2t2X202#0P0~0F1T0L1K2y0b0/030n0n0S2$0T1P2!0I0K0R0K0A0@0o0A1a0L2-2:0^2/2b2=1#2@2_2{2}0T2 01313335372S3a3a3e0R3h3j1`3l2D2O013q0L2`1i2|0M2~3032340Y3A2#3C0l3e0l3G2C3k0_3K3o0/3N3P053R3T3w3V3z2Q3B3b0i3e0i3(1b3*3m2;1u3p0I2^3O3s3S3u3U3y3X3`3Z3b0w3e0w402,3+2:3L3/4a3?3x3W364g393b0d3e0d4m423,453.473r3Q3t3v4u3_383C0h3e0h4D3I4o3n4G3M4I494K4b4M3^4f4P3b0t3e0t4U2E4W442Y4Z483:3=4c3@4e4w4+0K0p3e0p4:3J4p3-4^4J3;4L4d4v3Y4y3c0s0@0A0s554=4q4!4`5c4}5e4x3C0A3d045w5m435o4_4s4|4N4*3{3c1}5y3F0y3i3)4V5B584r4$4t4)4 5I0A3#5y3%5N3H4;5R4Y5T5b4%5d4O5Y3}5y3 5%5P2E1l2*1a2V2I0c1;2N584v2U1r1i2)0T2+3k5_1i4v6a2b0g0c0/322D5v3s6h6j4~5f6m0o2g0T6p5t505x3(4F4@0U0@0Y0b6c5*4@0J3e6H6B2?0b0@2Q1q0S0T0n2y0S0r0P2q0z0T6M574Y0?040C6%4X4@0e0@0z3O0T6Y0v6-4?206*0W6c0o6I2?0@0S0g1W6$413I711#6}6 7a3.6E0T0B166`3L7c782E706N3p0@22197n6f6{7b0@0E0N6c0_7v5B6o016k2:3C5K5b7G5W6r3b1}6t266v7H6q5u7Q1T5%0o7#7p6(6C6Q6G7v7%6.72040Y7i0u7d7q0/0I0@020H0u0G7@7(7/7t7k586*7B7v7D2.3K7N0n6l3b5!7M6i7V6x5I3#7S276w5:4h0K8g7!7$8v7e016D042y0u6Y7u2,7-7x0/0U0S0@0V18774n7k8c8e0K5=8h8p5H8r3}8n7U7O7X8T7Z3i8w7^3M0@0f0$0g6@807.1#7`040j8?8H016*6,7E8,6:7:7h7j7,8x8_0O8|4q7s2Q846)7z9b588_0y0y9i4Y8/0@5M8P914p8R7J4i6n8i8$504j8!8W5X8r4j2F8*7$8x8z0g7+8F8x936=1X6^9f4@6*0x9V7/8/1P8=9t8@0/6*0k9n4@8_7|7~9-7/74769Z7y04879s8a9u9z8d9w0K4A4K8c8k8r4A9D8j8q5ga43G8v8+811#8z8B8D9=7r046R0g6T6V2z6^1r8O6b8,8 9_7f049S6@6ZaB8~0@6~979273751XaH7m9PaM947=aQaJanaC9#8;0raY018_0Ka%9p5yaW040E7C8Qa08S4Ra5a0a75g4Raa9A5Ia^af9K8,8z4w9O3k8G9caD6?9U9(8}9XaH93a!9%9~9)aI049,aLai7_7{0F9;bqbm939@aPbe7l0@9|42bB9v1`3C4-a_9E7P0K4-a~7W50bKb2agb958ak0Zambw8}93aqas6Wav6#a.90blb$6;bcaGbB85aXb#babzax79azb_aSbr8-04bja$b`9j0@9ac79o0g5ja.aKc1bx9d8Eayc26*a:88a=6p8S52bLab8X5g52bQa{3CctbUbW4Yb50%b}5`b 9{a;bGa?a25k9ybM8%cQczac5v5i9I04bV7#9L0@al0Pck3IcE6/8.8:bkbFb/0obH0e5v6z2|a6cW3b5w1~6ucS6y6z5%89cl6gcObIc 7Lc|a`c~5Jd17Td35Y7Ld6cq7V8S5ZcRcv9F5gdrcVcw5v8t5Ob47gb7b~c26Kc!bh6Pap0e6ScI7wbC6+bhb;9Tb?c?b^04cgb89QaN9^b@9ga/bE5QcNcrcP8Udedk8r0A8Zd2dtbNd@8)c!b3c2bY8Cc*a%b%dMar6Ub*6Zawb-dSbbdU6_d(9Wc0d!aTb|cfa+cd045leh6|ejc,9Q0B0@2fecesaoaEbddWd)coch8}a)eoceeB9*9hcp7E0y6e5{695}661a0u60eY2L2G0L762F5~7D0Y0!0$0v04.