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!

Outils d'IA chauds

Undress AI Tool
Images de déshabillage gratuites

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

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

Clothoff.io
Dissolvant de vêtements AI

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 !

Article chaud

Outils chauds

Bloc-notes++7.3.1
Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise
Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1
Puissant environnement de développement intégré PHP

Dreamweaver CS6
Outils de développement Web visuel

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

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

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

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

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

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 (

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,

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

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