Maison développement back-end C++ Tas binaire et arbre de recherche binaire en C++

Tas binaire et arbre de recherche binaire en C++

Aug 22, 2023 pm 04:10 PM
c++ Arbre de recherche binaire tas binaire

Tas binaire et arbre de recherche binaire en C++

En programmation C++, le tas binaire et l'arbre de recherche binaire sont deux structures de données couramment utilisées. Elles présentent des similitudes, mais elles présentent également des différences. Cet article présentera respectivement les concepts, les opérations de base et les scénarios d'application des tas binaires et des arbres de recherche binaires.

1. Tas binaire

1.1 Concept

Un tas binaire est un arbre binaire complet qui satisfait les deux propriétés suivantes :

1.1.1 Ordre des tas

L'ordre des tas signifie que dans un tas binaire, chacun La valeur de chacun Le nœud n’est pas supérieur (ni inférieur) à la valeur de son nœud parent. Ici, nous prenons le tas maximum comme exemple, c'est-à-dire que la valeur du nœud racine est la plus grande valeur de tout l'arborescence et que les valeurs de tous les nœuds enfants sont inférieures ou égales à la valeur du nœud racine.

1.1.2 Propriétés complètes de l'arbre binaire

À l'exception de la couche la plus basse, toutes les autres couches doivent être remplies et tous les nœuds doivent être alignés à gauche.

Ici, le tableau suivant est utilisé pour représenter un tas maximum :

[ 16, 14, 10, 8, 7, 9, 3, 2, 4, 1 ]

Le tas correspondant est comme indiqué ci-dessous :

16

/
14 10
/ /
8 7 9 3
/
2 4

1

1.2 Opérations de base

1.2.1 Opération d'insertion

Insérer un nouvel élément dans un tas binaire, en utilisant " Ajuster par " passer au crible " :

  • Insérez le nouvel élément dans l'espace vide le plus à gauche en bas du tas ;
  • Comparez le nouvel élément avec son nœud parent, si la valeur du nouvel élément est supérieure à celle de son nœud parent, puis échangez le positions des deux, et répétez ce processus jusqu'à ce que le nouvel élément ne soit plus plus grand que son nœud parent ou atteigne le sommet du tas.

1.2.2 Opération de suppression

L'opération de suppression de l'élément supérieur du tas dans un tas binaire est ajustée en utilisant la méthode "sift down":

  • L'élément supérieur du tas et l'élément le plus à droite au niveau le bas du tas est ajusté Échange d'éléments ;
  • Supprimez l'élément supérieur d'origine du tas ;
  • Comparez le nouvel élément supérieur du tas avec ses nœuds enfants couche par couche si sa valeur est inférieure à la valeur maximale dans l'enfant. nœud, comparez-le avec la valeur maximale du nœud enfant. Les valeurs sont échangées et ce processus est répété jusqu'à ce que l'ordre du tas soit satisfait.

1.3 Scénarios d'application

Le tas binaire est souvent utilisé pour implémenter des files d'attente prioritaires et des algorithmes de tri basés sur le tas, tels que le tri par tas, le problème topK, etc.

2. Arbre de recherche binaire

2.1 Concept

L'arbre de recherche binaire (BST) est un arbre ordonné qui satisfait aux propriétés suivantes :

2.1.1 Les valeurs de tous les nœuds du sous-arbre de gauche sont égales et inférieures à la valeur de son nœud racine.

2.1.2 Les valeurs de tous les nœuds du sous-arbre droit sont supérieures à la valeur de son nœud racine.

2.1.3 Les sous-arbres gauche et droit sont également respectivement des arbres de recherche binaires.

Prenons l'exemple de l'arbre suivant :

    6
  /   
 2     7

/
1 4 9

   /    /
  3   5 8

Alors c'est un arbre de recherche binaire.

2.2 Opérations de base

2.2.1 Opération de recherche

L'opération de recherche d'un nœud dans un arbre de recherche binaire L'essence est de comparer en permanence la taille de la valeur du nœud à trouver avec la valeur actuelle du nœud et d'avancer. la recherche récursive du sous-arbre gauche/droite.

2.2.2 Opération d'insertion

L'opération d'insertion d'un nouveau nœud dans un arbre de recherche binaire nécessite une comparaison en partant du nœud racine et en trouvant la position où il doit être inséré. Après l'insertion, les propriétés de l'arbre de recherche binaire doivent. se satisfaire.

2.2.3 Opération de suppression

L'opération de suppression d'un nœud dans l'arbre de recherche binaire peut être divisée en trois situations :

  • Le nœud à supprimer est un nœud feuille, il suffit de le supprimer directement
  • Il n'y a que ; un nœud à supprimer
  • Lorsque le nœud à supprimer a deux nœuds enfants, remplacez le nœud par le plus petit nœud du sous-arbre droit du nœud, et supprimez le plus petit nœud du sous-arbre droit du nœud.

2.3 Scénarios d'application

Les arbres de recherche binaires sont souvent utilisés pour mettre en œuvre des scénarios avec des opérations de recherche et d'insertion tels que des dictionnaires et des tables de symboles. Les performances de recherche sont liées à la distribution des données.

3. Comparaison des tas binaires et des arbres de recherche binaires

3.1 Similitudes

Les tas binaires et les arbres de recherche binaires sont tous deux des arbres binaires et ont certaines des mêmes propriétés :

  • La position initiale du nœud racine peut être C'est n'importe quel nœud ;
  • peut être utilisé pour implémenter une file d'attente prioritaire ;
  • La complexité temporelle de l'insertion et de la suppression est O(logn).

3.2 Différences

Il existe également des différences évidentes entre les tas binaires et les arbres de recherche binaires :

3.2.1 Distribution des données

Dans un tas binaire, les éléments sont répartis entre les nœuds sans aucune régularité. Dans , c'est seulement nécessaire pour garantir que chaque nœud satisfait à l'ordre du tas ; dans un arbre de recherche binaire, la taille des éléments a une règle de tri spécifique, c'est-à-dire qu'elle satisfait la propriété de petite gauche et de grande droite.

3.2.2 Accès aux valeurs minimales/maximales

Dans un tas binaire, la valeur maximale/minimale est accessible en temps O(1), c'est-à-dire qu'elle est obtenue dans le nœud racine, mais la complexité temporelle d'accès aux autres elements est O(logn) ; dans un arbre de recherche binaire, trouver la valeur minimale/maximale nécessite de parcourir le sous-arbre, et la complexité temporelle est également O(logn).

3.2.3 Opérations de suppression et d'insertion

Dans un tas binaire, chaque opération de suppression et d'insertion doit suivre l'ordre du tas, c'est-à-dire la complexité temporelle de O(logn) dans un arbre de recherche binaire, trouver une complexité temporelle ; de nœuds et l'insertion d'un nouveau nœud est liée à la hauteur de l'arborescence, donc dans le pire des cas, cela peut nécessiter une complexité temporelle O(n).

3.3 Suggestions de sélection

Lors du choix d'un tas binaire et d'un arbre de recherche binaire, vous devez choisir en fonction des conditions spécifiques du scénario d'application.

Si vous avez besoin d'obtenir rapidement la valeur minimum/maximum et que vous n'avez pas d'exigence particulière sur la taille des éléments, vous pouvez donner la priorité au tas binaire.

Si vous devez insérer/supprimer des éléments rapidement et que les tailles des éléments doivent être triées dans un certain ordre, vous pouvez envisager de choisir un arbre de recherche binaire.

IV. Conclusion

En résumé, les tas binaires et les arbres de recherche binaires sont tous deux des structures de données importantes et ont leurs propres avantages et inconvénients dans différents scénarios. Comprendre les concepts, les opérations de base et les scénarios d'application des tas binaires et des arbres de recherche binaires est d'une grande importance pour l'écriture de programmes efficaces.

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 de ce site Web
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

Outils d'IA chauds

Undress AI Tool

Undress AI Tool

Images de déshabillage gratuites

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.

Clothoff.io

Clothoff.io

Dissolvant de vêtements AI

Video Face Swap

Video Face Swap

Échangez les visages dans n'importe quelle vidéo sans effort grâce à notre outil d'échange de visage AI entièrement gratuit !

Outils chauds

Bloc-notes++7.3.1

Bloc-notes++7.3.1

Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise

SublimeText3 version chinoise

Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1

Envoyer Studio 13.0.1

Puissant environnement de développement intégré PHP

Dreamweaver CS6

Dreamweaver CS6

Outils de développement Web visuel

SublimeText3 version Mac

SublimeText3 version Mac

Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Sujets chauds

Tutoriel PHP
1543
276
Prévisions de prix succinct (prouvoir): 2025, 2026, 2027-2030 Prévisions de prix succinct (prouvoir): 2025, 2026, 2027-2030 Aug 11, 2025 am 10:12 AM

Répertoire Qu'est-ce qui est succinct (prouvait) quel capital-risque soutient succinct (prouver)? Comment succinct (proue) Principe de travail SP1ZKVM et Network Prover OpsucCinct TECHNOLY CROSS-CHANNE Vérification PROUVE Économie Token Détails de jetons 2025, 2026, 2027-2030 Succinct (prouvure) Prévisions de prix Succinct (PROVE) PRIVANCE SUCHINCCING (PROVE) PRÉCISSION PRIX: Extension du volume de négociation et listing Momentum 2025-20

Que dois-je faire si l'application ne peut pas démarrer normalement (0xc0000906)? Voir la solution ici Que dois-je faire si l'application ne peut pas démarrer normalement (0xc0000906)? Voir la solution ici Aug 13, 2025 pm 06:42 PM

Lors de l'ouverture du logiciel ou du jeu, une invite apparaît soudainement que "l'application ne peut pas démarrer normalement (0xc0000906)" apparaît, et de nombreux utilisateurs seront confus et ne savent pas par où commencer. En fait, la plupart de ces erreurs sont causées par la corruption de fichiers système ou les bibliothèques d'exécution manquantes. Ne vous précipitez pas pour réinstaller le système. Cet article vous fournit plusieurs solutions simples et efficaces pour vous aider à restaurer rapidement le programme à exécuter. 1. Quelle est l'erreur de 0xc0000906? Le code d'erreur 0xc0000906 est une exception de démarrage courante dans les systèmes Windows, ce qui signifie généralement que le programme ne peut pas charger les composants système nécessaires ou l'exécution de l'environnement lors de l'exécution. Ce problème se produit souvent lors de l'exécution de grands logiciels ou de jeux. Les principales raisons peuvent inclure: la bibliothèque d'exécution nécessaire n'est pas installée ou endommagée. Le package d'installation du logiciel est infini

C Ordre de mémoire Exemple détendu C Ordre de mémoire Exemple détendu Aug 08, 2025 am 01:00 AM

Memory_Order_Relaxed convient aux scénarios où seule l'atomicité est requise sans synchronisation ou garantie de commande, telles que les compteurs, les statistiques, etc. 1. Lors de l'utilisation de Memory_Order_Relaxed, les opérations peuvent être réorganisées par le compilateur ou le processeur tant que la dépendance aux données unique n'est pas détruite. 2. Dans l'exemple, plusieurs threads incrément le compteur atomique, car ils ne se soucient que de la valeur finale et l'opération est cohérente, l'ordre mémoire détendu est sûr et efficace. 3. Fetch_add et charge ne fournissent pas de synchronisation ou de contraintes séquentielles lors de l'utilisation de détente. 4. Dans l'exemple d'erreur, la synchronisation du producteur-consommateur est implémentée à l'aide de détente, ce qui peut amener le consommateur à lire les valeurs de données unpulées car il n'y a pas de garantie d'ordre. 5. La bonne façon est

Comment obtenir la taille d'un fichier en c Comment obtenir la taille d'un fichier en c Aug 11, 2025 pm 12:34 PM

Utilisez les méthodes SeekG et Tellg de STD :: IFStream pour obtenir la taille du fichier sur les plates-formes. En ouvrant un fichier binaire et en le positionnant jusqu'au bout, utilisez Tellg () pour renvoyer le nombre d'octets; 2. Il est recommandé d'utiliser STD :: FileSystem :: File_Size pour C 17 et supérieur. Le code est concis et les erreurs sont gérées par le biais d'exceptions. La norme C 17 doit être activée; 3. Sur les systèmes POSIX, la fonction STAT () peut être utilisée pour obtenir efficacement la taille du fichier, ce qui convient aux scénarios sensibles aux performances. La méthode appropriée doit être sélectionnée en fonction du compilateur et de la plate-forme, et STD :: Système de fichiers doit être utilisé en premier (si disponible), autrement utiliser IFStream pour assurer la compatibilité ou utiliser ST sur les systèmes UNIX

Comment utiliser des expressions régulières en c Comment utiliser des expressions régulières en c Aug 12, 2025 am 10:46 AM

Pour utiliser des expressions régulières en C, vous devez inclure des fichiers d'en-tête et utiliser les fonctions qu'il fournit pour la correspondance des modèles et le traitement de texte. 1. Utilisez Std :: Regex_Match pour correspondre à la chaîne complète, et renvoyez True uniquement lorsque la chaîne entière se conforme au modèle; 2. Utilisez Std :: Regex_Search pour trouver des correspondances à n'importe quelle position de la chaîne; 3. Utilisez STD :: Smatch pour extraire le groupe de capture, obtenez la correspondance complète via des correspondances [0], des matchs [1] et des sous-matchs ultérieurs; 4. Utilisez STD :: Regex_Replace pour remplacer le texte correspondant et prendre en charge le groupe de capture par des références telles que 1 $ et 2 $; 5. Vous pouvez ajouter un ISET lors de la construction du regex (

Comment corriger MSVCP71.dll dans votre ordinateur? Il n'y a que trois méthodes requises Comment corriger MSVCP71.dll dans votre ordinateur? Il n'y a que trois méthodes requises Aug 14, 2025 pm 08:03 PM

L'ordinateur invite "MSVCP71.DLL est absent de l'ordinateur", ce qui est généralement dû au fait que le système manque de composants en cours d'exécution, ce qui fait que le logiciel ne charge pas normalement. Cet article analysera profondément les fonctions du fichier et la cause profonde de l'erreur, et fournira trois solutions efficaces pour vous aider à restaurer rapidement le programme à exécuter. 1. Qu'est-ce que msvcp71.dll? MSVCP71.DLL appartient au fichier de bibliothèque d'exécution de base de Microsoft Visualc 2003 et appartient au type de bibliothèque de liens dynamiques (DLL). Il est principalement utilisé pour prendre en charge les programmes écrits en C pour appeler les fonctions standard, les modèles STL et les modules de traitement de base de données. De nombreuses applications et jeux classiques développés au début des années 2000 reposent sur ce fichier à exécuter. Une fois le fichier manquant ou corrompu,

C Exemple de surcharge de l'opérateur C Exemple de surcharge de l'opérateur Aug 15, 2025 am 10:18 AM

La surcharge de l'opérateur en C permet d'attribuer de nouveaux comportements des opérateurs standard aux types personnalisés, 1. Renvoie de nouveaux objets via la surcharge de la fonction membre; 2. Overload = modifier l'objet actuel et la référence de retour; 3. Fonction d'amie surcharge

Comment rédiger un makefile de base pour un projet C? Comment rédiger un makefile de base pour un projet C? Aug 15, 2025 am 11:17 AM

AbasicMakeFileAutomatesC Compilation par définition de produits avec des objectifs, des dépendances et des commandes.2.

See all articles