recherche
Maisondéveloppement back-endTutoriel PythonRecherche binaire || Python || Structures de données et algorithmes

Binary Search || Python || Data Structures and Algorithms

Recherche binaire

La

Recherche binaire est un algorithme qui divise à plusieurs reprises l'espace de recherche en deux. Cette technique de recherche suit la stratégie diviser pour mieux régner. L'espace de recherche se réduit toujours de moitié à chaque itération, ce qui entraîne une complexité temporelle de O(log(n)), où n est le nombre d'éléments.

Condition : Les tableaux doivent être triés mais ils peuvent également être appliqués à des fonctions monotones où nous devons trouver l'augmentation ou la diminution monotone.

Cela fonctionne lorsque nous devons affiner l'espace de recherche en temps logarithmique.

Nous utilisons deux pointeurs, gauche et droite. Faites la moyenne de gauche et de droite pour trouver l'élément médian.

Maintenant, nous vérifions où nous devons déplacer nos pointeurs gauche et droit en fonction de la condition.

Principalement, trois étapes sont nécessaires pour résoudre un problème :

  1. Pré-traitement : Triez l'entrée si elle n'est pas triée.
  2. Recherche binaire : Utilisez deux pointeurs et trouvez le milieu pour diviser l'espace de recherche, puis choisissez la bonne moitié en conséquence.
  3. Post-traitement : Déterminez le résultat.

Avantages de l'algorithme de recherche binaire - La recherche binaire est plus rapide que la recherche linéaire pour les données volumineuses car elle coupe le tableau de moitié à chaque fois, au lieu de vérifier chaque élément un par un. Cela le rend plus rapide et plus efficace.

Limitations : La recherche binaire ne fonctionne que sur les tableaux triés, elle n'est donc pas efficace pour les petits tableaux non triés car le tri prend plus de temps. Cela ne fonctionne pas non plus aussi bien que la recherche linéaire pour les petites recherches en mémoire.

Applications : Il est utilisé pour rechercher un élément dans un tableau trié avec une complexité temporelle O(log(n)) et il peut également être utilisé pour trouver le plus petit ou le plus grand élément du tableau.

Code de recherche binaire de base -

Code

def binarySearch(nums, target):
    if len(nums) == 0:
        return -1

    left, right = 0, len(nums) - 1

    while left  right
    return -1

33. Rechercher dans un tableau trié avec rotation
Étant donné le tableau nums après la rotation possible et une cible entière, renvoie l'index de la cible s'il est en nombres, ou -1 s'il n'est pas en nombres.
Vous devez écrire un algorithme avec une complexité d'exécution O(log n).
Exemple 1 :
Entrée : nums = [4,5,6,7,0,1,2], cible = 0
Sortie : 4

Exemple 2 :
Entrée : nums = [4,5,6,7,0,1,2], cible = 3
Sortie : -1

Exemple 3 :
Entrée : nums = [1], cible = 0
Sortie : -1

Code

def binarySearch(nums, target):
    if len(nums) == 0:
        return -1

    left, right = 0, len(nums) - 1

    while left  right
    return -1
  1. Utilisez deux pointeurs, gauche et droite, et répétez jusqu'à ce qu'ils se chevauchent.
  2. Trouvez l'élément intermédiaire.
  3. Puisque le tableau est trié mais pivoté, nous ne pouvons pas simplement comparer les éléments gauche ou droit avec le milieu.
  4. Tout d'abord, déterminez quelle partie gauche ou droite est triée en comparant le pointeur central avec le pointeur gauche ou droit.
  5. Sur la base de cette conclusion, ajustez les pointeurs en conséquence.

Complexité temporelle - O(log(n)) car l'espace de recherche est divisé en deux à chaque itération.
Complexité spatiale - O(1)

Augmentation monotone

162. Trouver l'élément Peak

Un élément pic est un élément strictement supérieur à ses voisins.
Étant donné un tableau d'entiers indexés à 0, recherchez un élément de pointe et renvoyez son index. Si le tableau contient plusieurs pics, renvoyez l'index à l'un des pics.
Vous pouvez imaginer que nums[-1] = nums[n] = -∞. Autrement dit, un élément est toujours considéré comme strictement supérieur à un voisin extérieur au tableau.
Vous devez écrire un algorithme qui s'exécute en un temps O(log n).

Exemple 1 :
Entrée : nombres = [1,2,3,1]
Sortie : 2
Explication : 3 est un élément de pointe et votre fonction doit renvoyer le numéro d'index 2.
Exemple 2 :
Entrée : nombres = [1,2,1,3,5,6,4]
Sortie : 5
Explication : Votre fonction peut renvoyer soit le numéro d'index 1 où l'élément de pic est 2, soit le numéro d'index 5 où l'élément de pic est 6.

Code

class Solution:
    def search(self, nums: List[int], target: int) -> int:
        left = 0
        right = len(nums)-1

        while left = nums[left]:
                # if nums[mid]= nums[left]:
                if nums[left] 



<ol>
<li>Dans ce type de problème, il faut vérifier le pic en comparant l'élément gauche ou droit du milieu.</li>
<li>Cela permet de déterminer si le graphique a une tendance à la hausse ou à la baisse.</li>
<li>Pour trouver le maximum, recherchez la pente ascendante et explorez le bon sous-espace.</li>
<li>Pour trouver le minimum, recherchez le sous-espace de gauche</li>
</ol>

<p><strong>Complexité temporelle - O(log(n))</strong> car l'espace de recherche est divisé en deux à chaque itération.<br>
<strong>Complexité spatiale - O(1)</strong></p>


          

            
        

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Python vs C: applications et cas d'utilisation comparésPython vs C: applications et cas d'utilisation comparésApr 12, 2025 am 12:01 AM

Python convient à la science des données, au développement Web et aux tâches d'automatisation, tandis que C convient à la programmation système, au développement de jeux et aux systèmes intégrés. Python est connu pour sa simplicité et son écosystème puissant, tandis que C est connu pour ses capacités de contrôle élevées et sous-jacentes.

Le plan Python de 2 heures: une approche réalisteLe plan Python de 2 heures: une approche réalisteApr 11, 2025 am 12:04 AM

Vous pouvez apprendre les concepts de programmation de base et les compétences de Python dans les 2 heures. 1. Apprenez les variables et les types de données, 2. Flux de contrôle maître (instructions et boucles conditionnelles), 3. Comprenez la définition et l'utilisation des fonctions, 4. Démarrez rapidement avec la programmation Python via des exemples simples et des extraits de code.

Python: Explorer ses applications principalesPython: Explorer ses applications principalesApr 10, 2025 am 09:41 AM

Python est largement utilisé dans les domaines du développement Web, de la science des données, de l'apprentissage automatique, de l'automatisation et des scripts. 1) Dans le développement Web, les cadres Django et Flask simplifient le processus de développement. 2) Dans les domaines de la science des données et de l'apprentissage automatique, les bibliothèques Numpy, Pandas, Scikit-Learn et Tensorflow fournissent un fort soutien. 3) En termes d'automatisation et de script, Python convient aux tâches telles que les tests automatisés et la gestion du système.

Combien de python pouvez-vous apprendre en 2 heures?Combien de python pouvez-vous apprendre en 2 heures?Apr 09, 2025 pm 04:33 PM

Vous pouvez apprendre les bases de Python dans les deux heures. 1. Apprenez les variables et les types de données, 2. Structures de contrôle maître telles que si les instructions et les boucles, 3. Comprenez la définition et l'utilisation des fonctions. Ceux-ci vous aideront à commencer à écrire des programmes Python simples.

Comment enseigner les bases de la programmation novice en informatique dans le projet et les méthodes axées sur les problèmes dans les 10 heures?Comment enseigner les bases de la programmation novice en informatique dans le projet et les méthodes axées sur les problèmes dans les 10 heures?Apr 02, 2025 am 07:18 AM

Comment enseigner les bases de la programmation novice en informatique dans les 10 heures? Si vous n'avez que 10 heures pour enseigner à l'informatique novice des connaissances en programmation, que choisissez-vous d'enseigner ...

Comment éviter d'être détecté par le navigateur lors de l'utilisation de Fiddler partout pour la lecture de l'homme au milieu?Comment éviter d'être détecté par le navigateur lors de l'utilisation de Fiddler partout pour la lecture de l'homme au milieu?Apr 02, 2025 am 07:15 AM

Comment éviter d'être détecté lors de l'utilisation de FiddlereVerywhere pour les lectures d'homme dans le milieu lorsque vous utilisez FiddlereVerywhere ...

Que dois-je faire si le module '__builtin__' n'est pas trouvé lors du chargement du fichier de cornichon dans Python 3.6?Que dois-je faire si le module '__builtin__' n'est pas trouvé lors du chargement du fichier de cornichon dans Python 3.6?Apr 02, 2025 am 07:12 AM

Chargement des fichiers de cornichons dans Python 3.6 Rapport de l'environnement Erreur: modulenotFoundError: NomoduLenamed ...

Comment améliorer la précision de la segmentation des mots jieba dans l'analyse des commentaires pittoresques?Comment améliorer la précision de la segmentation des mots jieba dans l'analyse des commentaires pittoresques?Apr 02, 2025 am 07:09 AM

Comment résoudre le problème de la segmentation des mots jieba dans l'analyse des commentaires pittoresques? Lorsque nous effectuons des commentaires et des analyses pittoresques, nous utilisons souvent l'outil de segmentation des mots jieba pour traiter le texte ...

See all articles

Outils d'IA chauds

Undresser.AI Undress

Undresser.AI Undress

Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover

AI Clothes Remover

Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool

Undress AI Tool

Images de déshabillage gratuites

Clothoff.io

Clothoff.io

Dissolvant de vêtements AI

AI Hentai Generator

AI Hentai Generator

Générez AI Hentai gratuitement.

Article chaud

R.E.P.O. Crystals d'énergie expliqués et ce qu'ils font (cristal jaune)
3 Il y a quelques semainesBy尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Meilleurs paramètres graphiques
3 Il y a quelques semainesBy尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Comment réparer l'audio si vous n'entendez personne
3 Il y a quelques semainesBy尊渡假赌尊渡假赌尊渡假赌
WWE 2K25: Comment déverrouiller tout dans Myrise
3 Il y a quelques semainesBy尊渡假赌尊渡假赌尊渡假赌

Outils chauds

Télécharger la version Mac de l'éditeur Atom

Télécharger la version Mac de l'éditeur Atom

L'éditeur open source le plus populaire

MantisBT

MantisBT

Mantis est un outil Web de suivi des défauts facile à déployer, conçu pour faciliter le suivi des défauts des produits. Cela nécessite PHP, MySQL et un serveur Web. Découvrez nos services de démonstration et d'hébergement.

ZendStudio 13.5.1 Mac

ZendStudio 13.5.1 Mac

Puissant environnement de développement intégré PHP

Version crackée d'EditPlus en chinois

Version crackée d'EditPlus en chinois

Petite taille, coloration syntaxique, ne prend pas en charge la fonction d'invite de code

Listes Sec

Listes Sec

SecLists est le compagnon ultime du testeur de sécurité. Il s'agit d'une collection de différents types de listes fréquemment utilisées lors des évaluations de sécurité, le tout en un seul endroit. SecLists contribue à rendre les tests de sécurité plus efficaces et productifs en fournissant facilement toutes les listes dont un testeur de sécurité pourrait avoir besoin. Les types de listes incluent les noms d'utilisateur, les mots de passe, les URL, les charges utiles floues, les modèles de données sensibles, les shells Web, etc. Le testeur peut simplement extraire ce référentiel sur une nouvelle machine de test et il aura accès à tous les types de listes dont il a besoin.