Maison développement back-end tutoriel php La structure de données basée sur une table de hachage optimise les calculs d'intersection et d'union des tableaux PHP

La structure de données basée sur une table de hachage optimise les calculs d'intersection et d'union des tableaux PHP

May 02, 2024 pm 12:06 PM
优化 数据结构

Utilisez une table de hachage pour optimiser les calculs d'intersection et d'union de tableaux PHP, en réduisant la complexité temporelle de O(n * m) à O(n + m). Les étapes spécifiques sont les suivantes : Utilisez une table de hachage pour ajouter les éléments du. premier tableau Mapper la valeur booléenne pour savoir rapidement si l'élément existe dans le deuxième tableau et améliorer l'efficacité du calcul d'intersection. Utilisez une table de hachage pour marquer les éléments du premier tableau comme existants, puis ajoutez les éléments du deuxième tableau un par un, en ignorant les éléments existants pour améliorer l'efficacité des calculs d'union.

La structure de données basée sur une table de hachage optimise les calculs dintersection et dunion des tableaux PHP

Optimisation de l'intersection et du calcul d'union de tableaux PHP basés sur la table de hachage

Avant-propos

Le traitement de l'intersection et de l'union de tableaux en PHP est une opération courante, en particulier lorsque de grandes quantités de données sont impliquées. Pour optimiser ces calculs, nous pouvons utiliser des tables de hachage pour améliorer considérablement l'efficacité.

Table de hachage

Une table de hachage est une structure de données qui mappe les clés aux valeurs. Une propriété clé d’une table de hachage est qu’elle peut rechercher et insérer des éléments de manière très efficace.

Optimiser le calcul d'intersection de tableaux à l'aide d'une table de hachage

Considérez le code suivant, qui calcule l'intersection de deux tableaux :

function intersect($arr1, $arr2) {
  $result = [];

  foreach ($arr1 as $value) {
    if (in_array($value, $arr2)) {
      $result[] = $value;
    }
  }

  return $result;
}
Copier après la connexion

La complexité temporelle de ce code est O(n * m), où n et m sont respectivement arr1 et la longueur de arr2. Nous pouvons utiliser une table de hachage pour mapper les éléments de arr1 à une valeur booléenne indiquant si l'élément est présent dans arr1. Nous pouvons ensuite parcourir arr2 et trouver rapidement si un élément est présent dans arr1 en utilisant la valeur de la clé correspondante dans la table de hachage.

function intersect_hash($arr1, $arr2) {
  $lookup = [];

  foreach ($arr1 as $value) {
    $lookup[$value] = true;
  }

  $result = [];

  foreach ($arr2 as $value) {
    if (isset($lookup[$value])) {
      $result[] = $value;
    }
  }

  return $result;
}
Copier après la connexion

La complexité temporelle de ce code est O(n + m) car il ne parcourt chaque tableau qu'une seule fois.

Utilisez la table de hachage pour optimiser le calcul des unions de tableaux

Pour le calcul des unions de tableaux, nous pouvons également utiliser la table de hachage. Tout d’abord, nous mappons les éléments du premier tableau dans une table de hachage. Nous ajoutons ensuite chaque élément du deuxième tableau à la table de hachage, en l'ignorant s'il existe déjà.

function union($arr1, $arr2) {
  $lookup = [];

  foreach ($arr1 as $value) {
    $lookup[$value] = true;
  }

  foreach ($arr2 as $value) {
    $lookup[$value] = true;
  }

  $result = array_keys($lookup);

  return $result;
}
Copier après la connexion

La complexité temporelle de ce code est O(n + m) car il ne parcourt chaque tableau qu'une seule fois.

Cas pratique

Supposons que nous ayons deux tableaux d'une longueur de 100 000 et 50 000. Le temps moyen requis pour calculer l'intersection et l'union en utilisant respectivement l'implémentation d'origine et l'implémentation optimisée de la table de hachage est le suivant : Secondes

0,05 secondesUnion1,80 secondes0,10 secondes
Comme nous pouvons le constater, la mise en œuvre de l'optimisation des tables de hachage améliore considérablement l'efficacité des calculs d'intersection et d'union.

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

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 semaines By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Meilleurs paramètres graphiques
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Comment réparer l'audio si vous n'entendez personne
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
WWE 2K25: Comment déverrouiller tout dans Myrise
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌

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)

Comparez des structures de données complexes à l'aide de la comparaison de fonctions Java Comparez des structures de données complexes à l'aide de la comparaison de fonctions Java Apr 19, 2024 pm 10:24 PM

Lors de l'utilisation de structures de données complexes en Java, Comparator est utilisé pour fournir un mécanisme de comparaison flexible. Les étapes spécifiques comprennent : la définition d’une classe de comparaison et la réécriture de la méthode de comparaison pour définir la logique de comparaison. Créez une instance de comparaison. Utilisez la méthode Collections.sort, en transmettant les instances de collection et de comparateur.

Optimisation des programmes C++ : techniques de réduction de la complexité temporelle Optimisation des programmes C++ : techniques de réduction de la complexité temporelle Jun 01, 2024 am 11:19 AM

La complexité temporelle mesure le temps d'exécution d'un algorithme par rapport à la taille de l'entrée. Les conseils pour réduire la complexité temporelle des programmes C++ incluent : le choix des conteneurs appropriés (tels que vecteur, liste) pour optimiser le stockage et la gestion des données. Utilisez des algorithmes efficaces tels que le tri rapide pour réduire le temps de calcul. Éliminez les opérations multiples pour réduire le double comptage. Utilisez des branches conditionnelles pour éviter les calculs inutiles. Optimisez la recherche linéaire en utilisant des algorithmes plus rapides tels que la recherche binaire.

Structures de données et algorithmes Java : explication détaillée Structures de données et algorithmes Java : explication détaillée May 08, 2024 pm 10:12 PM

Les structures de données et les algorithmes sont à la base du développement Java. Cet article explore en profondeur les structures de données clés (telles que les tableaux, les listes chaînées, les arbres, etc.) et les algorithmes (tels que le tri, la recherche, les algorithmes graphiques, etc.) en Java. Ces structures sont illustrées par des exemples pratiques, notamment l'utilisation de tableaux pour stocker les scores, de listes chaînées pour gérer les listes de courses, de piles pour implémenter la récursion, de files d'attente pour synchroniser les threads, ainsi que d'arbres et de tables de hachage pour une recherche et une authentification rapides. Comprendre ces concepts vous permet d'écrire du code Java efficace et maintenable.

Structure de données PHP : l'équilibre des arborescences AVL, maintenant une structure de données efficace et ordonnée Structure de données PHP : l'équilibre des arborescences AVL, maintenant une structure de données efficace et ordonnée Jun 03, 2024 am 09:58 AM

L'arbre AVL est un arbre de recherche binaire équilibré qui garantit des opérations de données rapides et efficaces. Pour atteindre l'équilibre, il effectue des opérations de virage à gauche et à droite, en ajustant les sous-arbres qui violent l'équilibre. Les arbres AVL utilisent l'équilibrage de hauteur pour garantir que la hauteur de l'arbre est toujours petite par rapport au nombre de nœuds, réalisant ainsi des opérations de recherche de complexité temporelle logarithmique (O (logn)) et maintenant l'efficacité de la structure de données même sur de grands ensembles de données.

Comment optimiser les éléments de démarrage du système WIN7 Comment optimiser les éléments de démarrage du système WIN7 Mar 26, 2024 pm 06:20 PM

1. Appuyez sur la combinaison de touches (touche Win + R) sur le bureau pour ouvrir la fenêtre d'exécution, puis entrez [regedit] et appuyez sur Entrée pour confirmer. 2. Après avoir ouvert l'éditeur de registre, nous cliquons pour développer [HKEY_CURRENT_USERSoftwareMicrosoftWindowsCurrentVersionExplorer], puis voyons s'il y a un élément Sérialiser dans le répertoire. Sinon, nous pouvons cliquer avec le bouton droit sur Explorateur, créer un nouvel élément et le nommer Sérialiser. 3. Cliquez ensuite sur Sérialiser, puis cliquez avec le bouton droit sur l'espace vide dans le volet de droite, créez une nouvelle valeur de bit DWORD (32) et nommez-la Étoile.

Quels sont les moyens de résoudre les inefficacités des fonctions PHP ? Quels sont les moyens de résoudre les inefficacités des fonctions PHP ? May 02, 2024 pm 01:48 PM

Cinq façons d'optimiser l'efficacité des fonctions PHP : évitez la copie inutile de variables. Utilisez des références pour éviter la copie de variables. Évitez les appels de fonction répétés. Fonctions simples en ligne. Optimisation des boucles à l'aide de tableaux.

'Black Myth: Wukong ' La version Xbox a été retardée en raison d'une 'fuite de mémoire', l'optimisation de la version PS5 est en cours 'Black Myth: Wukong ' La version Xbox a été retardée en raison d'une 'fuite de mémoire', l'optimisation de la version PS5 est en cours Aug 27, 2024 pm 03:38 PM

Récemment, "Black Myth : Wukong" a attiré une énorme attention dans le monde entier. Le nombre d'utilisateurs en ligne simultanés sur chaque plateforme a atteint un nouveau sommet. Ce jeu a connu un grand succès commercial sur plusieurs plateformes. La version Xbox de "Black Myth : Wukong" a été reportée. Bien que "Black Myth : Wukong" soit sorti sur les plateformes PC et PS5, il n'y a pas eu de nouvelles définitives concernant sa version Xbox. Il est entendu que le responsable a confirmé que "Black Myth : Wukong" serait lancé sur la plateforme Xbox. Cependant, la date précise de lancement n’a pas encore été annoncée. Il a été récemment rapporté que le retard de la version Xbox était dû à des problèmes techniques. Selon un blogueur concerné, il a appris grâce aux communications avec les développeurs et les « initiés Xbox » lors de la Gamescom que la version Xbox de « Black Myth : Wukong » existe.

Comment utiliser les outils et bibliothèques pour optimiser les programmes C++ ? Comment utiliser les outils et bibliothèques pour optimiser les programmes C++ ? May 08, 2024 pm 05:09 PM

Dans le développement C++ moderne, l’utilisation d’outils et de bibliothèques d’optimisation est cruciale. Des outils tels que Valgrind, Perf et LLDB identifient les goulots d'étranglement, mesurent les performances et déboguent. Les bibliothèques telles que Eigen, Boost et OpenCV améliorent l'efficacité dans des domaines tels que l'algèbre linéaire, les E/S réseau et la vision par ordinateur. Par exemple, utilisez Eigen pour optimiser la multiplication matricielle, Perf pour analyser les performances du programme et Boost::Asio pour mettre en œuvre des E/S réseau efficaces.

See all articles