Maison développement back-end tutoriel php Explication détaillée de l'exemple d'algorithme de tri par tas PHP

Explication détaillée de l'exemple d'algorithme de tri par tas PHP

Aug 18, 2017 pm 01:25 PM
php 实例 详解

Cet article présente principalement l'algorithme de tri de tas implémenté en PHP, et analyse les principes, les étapes de mise en œuvre et les techniques de fonctionnement associées du tri de tas PHP sous forme d'exemples. Les amis dans le besoin peuvent s'y référer

Le. Les exemples de cet article décrivent l'algorithme de tri Heap implémenté en PHP. J'aimerais le partager avec vous pour votre référence. Les détails sont les suivants :

Expérience

J'ai travaillé pendant un entretien. pour l'entreprise pour laquelle je travaillais, j'ai été choqué par l'aspect technique. Non, car ma connaissance de la structure des données et d'autres bases est vraiment médiocre, même si au départ je voulais devenir designer. . . Cependant, comme je sais très bien écrire du PHP, je peux venir faire un stage, mais je suis toujours déterminé à rafraîchir les bases. En fait, j'ai déjà ressenti l'importance des bases. Certaines choses plus profondes sont de niveau relativement bas, et il n'y a aucun moyen de procéder sans bien les apprendre. Par exemple, j'ai déjà utilisé PHP pour créer des websockets, ce qui impliquait des concepts tels que des paquets de données et des trames de données. Je n'arrivais pas à comprendre et je ne pouvais même pas traiter les données que je devais rattraper plus tard. Je vais donc réapprendre les connaissances de base comme les structures de données, les algorithmes et les réseaux. Je voudrais aussi rappeler à tout le monde, n'allez pas dans la direction opposée comme moi, il sera même trop tard pour comprendre.

Aujourd'hui, parlons du problème de tri du tas qui a été posé. Lorsqu'on m'a posé la question à ce sujet, j'ai même oublié le concept d'arbre binaire complet. Heureusement, j'ai encore un peu de base sur la structure des données, et je le comprends un peu après avoir lu quelques informations, donc je veux utiliser PHP pour écrire une sorte d'arbres binaires en tas, et en passant, je passe également en revue les arbres binaires, les tas et d'autres structures de données.

Tas

Tas est un terme général désignant un type particulier de structure de données en informatique. Il s'agit généralement d'une structure de données. cela peut être un objet tableau vu comme un arbre.

Tas {k1,k2,ki,…,kn} (ki <= k2i,ki <= k2i+1)|(ki >= k2i,ki >= k2i+1), (i = 1,2,3,4...n/2)

A propos du tas :

La valeur d'un nœud dans le tas n'est toujours ni supérieur ni inférieur à la valeur de son nœud parent ;
Le tas est toujours un arbre binaire complet (ci-dessous).
Le tas avec le plus grand nœud racine est appelé tas maximum ou grand tas racine, et le tas avec le plus petit nœud racine est appelé tas minimum ou petit tas racine.

Arbre binaire complet

Quand il s'agit de tri par tas, nous devons mentionner les arbres binaires complets. Ces concepts de base sont partout. sur Internet, j'ai choisi le plus simple. .

Arbre binaire complet : À l'exception du dernier niveau, le nombre de nœuds à chaque niveau atteint le maximum ; il ne manque que quelques nœuds du côté droit au dernier niveau.

J'ai conclu que c'est précisément à cause des deux caractéristiques suivantes,

1 Seule la dernière couche est autorisée à avoir des nœuds vacants et les postes vacants sont à droite, c'est-à-dire. , les nœuds feuilles ne peuvent apparaître que sur les deux plus grands niveaux (régularité de la méthode de stockage
2. Si i>1, le parent de l'arbre est tree[i p 2] (régularité de ses valeurs de nœud parent et enfant) ; ;

rend le tri très pratique.

Tri par tas

Le tri par tas utilise le grand tas supérieur pour l'ordre croissant et le petit tas supérieur pour l'ordre décroissant.

Cet exemple utilise un petit tas supérieur par ordre décroissant pour analyser.

Les étapes de tri des tas sont les suivantes :

1 Nous créons un tableau $arr à partir des données (49, 38, 65, 97, 76, 13. , 27, 50) ;
2. Utilisez le tableau $arr pour créer un petit tas supérieur (les principales étapes seront expliquées dans les commentaires du code. La figure ci-dessous est le processus d'utilisation d'un tableau pour créer un petit tas supérieur );
3. Changez la racine du tas (le plus petit élément) est échangé avec la dernière feuille, et la longueur du tas est réduite de un et passe à la deuxième étape
4. Répétez les étapes 2- ; 3 jusqu'à ce qu'il n'y ait qu'un seul nœud dans le tas et que le tri soit terminé.

Implémentation PHP du tri par tas


//因为是数组,下标从0开始,所以,下标为n根结点的左子结点为2n+1,右子结点为2n+2;
//初始化值,建立初始堆
$arr=array(49,38,65,97,76,13,27,50);
$arrSize=count($arr);
//将第一次排序抽出来,因为最后一次排序不需要再交换值了。
buildHeap($arr,$arrSize);
for($i=$arrSize-1;$i>0;$i--){
  swap($arr,$i,0);
  $arrSize--;
  buildHeap($arr,$arrSize);
}
//用数组建立最小堆
function buildHeap(&$arr,$arrSize){
  //计算出最开始的下标$index,如图,为数字"97"所在位置,比较每一个子树的父结点和子结点,将最小值存入父结点中
  //从$index处对一个树进行循环比较,形成最小堆
  for($index=intval($arrSize/2)-1; $index>=0; $index--){
    //如果有左节点,将其下标存进最小值$min
    if($index*2+1<$arrSize){
      $min=$index*2+1;
      //如果有右子结点,比较左右结点的大小,如果右子结点更小,将其结点的下标记录进最小值$min
      if($index*2+2<$arrSize){
        if($arr[$index*2+2]<$arr[$min]){
          $min=$index*2+2;
        }
      }
      //将子结点中较小的和父结点比较,若子结点较小,与父结点交换位置,同时更新较小
      if($arr[$min]<$arr[$index]){
        swap($arr,$min,$index);
      }
    }
  }
}
//此函数用来交换下数组$arr中下标为$one和$another的数据
function swap(&$arr,$one,$another){
  $tmp=$arr[$one];
  $arr[$one]=$arr[$another];
  $arr[$another]=$tmp;
}
Copier après la connexion

Voici le résultat final du tri :

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

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

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)

Guide d'installation et de mise à niveau de PHP 8.4 pour Ubuntu et Debian Guide d'installation et de mise à niveau de PHP 8.4 pour Ubuntu et Debian Dec 24, 2024 pm 04:42 PM

PHP 8.4 apporte plusieurs nouvelles fonctionnalités, améliorations de sécurité et de performances avec une bonne quantité de dépréciations et de suppressions de fonctionnalités. Ce guide explique comment installer PHP 8.4 ou mettre à niveau vers PHP 8.4 sur Ubuntu, Debian ou leurs dérivés. Bien qu'il soit possible de compiler PHP à partir des sources, son installation à partir d'un référentiel APT comme expliqué ci-dessous est souvent plus rapide et plus sécurisée car ces référentiels fourniront les dernières corrections de bogues et mises à jour de sécurité à l'avenir.

7 fonctions PHP que je regrette de ne pas connaître auparavant 7 fonctions PHP que je regrette de ne pas connaître auparavant Nov 13, 2024 am 09:42 AM

Si vous êtes un développeur PHP expérimenté, vous aurez peut-être le sentiment d'y être déjà allé et de l'avoir déjà fait. Vous avez développé un nombre important d'applications, débogué des millions de lignes de code et peaufiné de nombreux scripts pour réaliser des opérations.

Comment configurer Visual Studio Code (VS Code) pour le développement PHP Comment configurer Visual Studio Code (VS Code) pour le développement PHP Dec 20, 2024 am 11:31 AM

Visual Studio Code, également connu sous le nom de VS Code, est un éditeur de code source gratuit – ou environnement de développement intégré (IDE) – disponible pour tous les principaux systèmes d'exploitation. Avec une large collection d'extensions pour de nombreux langages de programmation, VS Code peut être c

Expliquez les jetons Web JSON (JWT) et leur cas d'utilisation dans les API PHP. Expliquez les jetons Web JSON (JWT) et leur cas d'utilisation dans les API PHP. Apr 05, 2025 am 12:04 AM

JWT est une norme ouverte basée sur JSON, utilisée pour transmettre en toute sécurité des informations entre les parties, principalement pour l'authentification de l'identité et l'échange d'informations. 1. JWT se compose de trois parties: en-tête, charge utile et signature. 2. Le principe de travail de JWT comprend trois étapes: la génération de JWT, la vérification de la charge utile JWT et l'analyse. 3. Lorsque vous utilisez JWT pour l'authentification en PHP, JWT peut être généré et vérifié, et les informations sur le rôle et l'autorisation des utilisateurs peuvent être incluses dans l'utilisation avancée. 4. Les erreurs courantes incluent une défaillance de vérification de signature, l'expiration des jetons et la charge utile surdimensionnée. Les compétences de débogage incluent l'utilisation des outils de débogage et de l'exploitation forestière. 5. L'optimisation des performances et les meilleures pratiques incluent l'utilisation des algorithmes de signature appropriés, la définition des périodes de validité raisonnablement,

Comment analysez-vous et traitez-vous HTML / XML dans PHP? Comment analysez-vous et traitez-vous HTML / XML dans PHP? Feb 07, 2025 am 11:57 AM

Ce tutoriel montre comment traiter efficacement les documents XML à l'aide de PHP. XML (Language de balisage extensible) est un langage de balisage basé sur le texte polyvalent conçu à la fois pour la lisibilité humaine et l'analyse de la machine. Il est couramment utilisé pour le stockage de données et

Programme PHP pour compter les voyelles dans une chaîne Programme PHP pour compter les voyelles dans une chaîne Feb 07, 2025 pm 12:12 PM

Une chaîne est une séquence de caractères, y compris des lettres, des nombres et des symboles. Ce tutoriel apprendra à calculer le nombre de voyelles dans une chaîne donnée en PHP en utilisant différentes méthodes. Les voyelles en anglais sont a, e, i, o, u, et elles peuvent être en majuscules ou en minuscules. Qu'est-ce qu'une voyelle? Les voyelles sont des caractères alphabétiques qui représentent une prononciation spécifique. Il y a cinq voyelles en anglais, y compris les majuscules et les minuscules: a, e, i, o, u Exemple 1 Entrée: String = "TutorialSpoint" Sortie: 6 expliquer Les voyelles dans la chaîne "TutorialSpoint" sont u, o, i, a, o, i. Il y a 6 yuans au total

Expliquez la liaison statique tardive en PHP (statique: :). Expliquez la liaison statique tardive en PHP (statique: :). Apr 03, 2025 am 12:04 AM

Liaison statique (statique: :) ​​implémente la liaison statique tardive (LSB) dans PHP, permettant à des classes d'appel d'être référencées dans des contextes statiques plutôt que de définir des classes. 1) Le processus d'analyse est effectué au moment de l'exécution, 2) Recherchez la classe d'appel dans la relation de succession, 3) il peut apporter des frais généraux de performance.

Quelles sont les méthodes PHP Magic (__construct, __ destruct, __ call, __get, __set, etc.) et fournir des cas d'utilisation? Quelles sont les méthodes PHP Magic (__construct, __ destruct, __ call, __get, __set, etc.) et fournir des cas d'utilisation? Apr 03, 2025 am 12:03 AM

Quelles sont les méthodes magiques de PHP? Les méthodes magiques de PHP incluent: 1. \ _ \ _ Construct, utilisé pour initialiser les objets; 2. \ _ \ _ Destruct, utilisé pour nettoyer les ressources; 3. \ _ \ _ Appel, gérer les appels de méthode inexistants; 4. \ _ \ _ GET, Implémentez l'accès à l'attribut dynamique; 5. \ _ \ _ SET, Implémentez les paramètres d'attribut dynamique. Ces méthodes sont automatiquement appelées dans certaines situations, améliorant la flexibilité et l'efficacité du code.

See all articles