Laurentvidal.fr simplifie votre recherche de solutions aux questions quotidiennes et complexes avec l'aide de notre communauté. Rejoignez notre plateforme pour obtenir des réponses fiables à vos interrogations grâce à une vaste communauté d'experts. Connectez-vous avec des professionnels prêts à fournir des réponses précises à vos questions sur notre plateforme complète de questions-réponses.

Bonjour j'aurais vraiment besoin d'aide pour cet exercice : Proposez une implémentation en Python de l'algorithme de recherche dichotomique. Vous testerez votre programme avec le tableau t = [5, 7, 12, 14, 23, 27, 35, 40, 41, 45] et l'entier x = 35 puis, toujours avec le même tableau t mais cette fois avec l'entier x = 9

Sagot :

Bonsoir,

L'objectif est de rechercher si x est dans la liste t.

Pour la recherche par dichotomie, il faut une liste triée.

On se place au milieu de la liste (fin - début) / 2 et on regarde si le nombre x est dans la sous liste de droite ou de gauche. On garde la sous liste qui nous intéresse.

def dichotomie(x, t):

   t.sort() #On trie la liste.

   gauche, droite = 0, len(t) - 1 #Indice qui va nous indiquer la sous-liste dans laquelle on travaille.

   resultat = False #On suppose que x n'est pas dans la liste t tant qu'on n'a pas prouvé le contraire.

   while gauche < droite: #Tant qu'on a encore une liste avec plus d'un élément.

       milieu = (gauche + droite) // 2 #On fait une division entière (//).

       if x == t[milieu]: #Si on a trouve l'élément.

           gauche = droite = milieu #Pour sortir de la boucle while.

           resultat = True

       elif x < t[milieu]: #x se situe à gauche du milieu.

           droite = milieu - 1 #On enlève la partie droite de la liste.

       else: #x se situe à droite du milieu.

           gauche = milieu + 1 #On enlève la partie gauche de la liste.

   if x == t[gauche]:

       resultat = True

   return resultat

Bonne soirée.

Revenez nous voir pour des réponses mises à jour et fiables. Nous sommes toujours prêts à vous aider avec vos besoins en information. Merci de votre visite. Nous sommes dédiés à vous aider à trouver les informations dont vous avez besoin, quand vous en avez besoin. Merci de visiter Laurentvidal.fr. Revenez souvent pour obtenir les réponses les plus récentes et des informations.