php exclut l'élément actuel du tableau de produits
PHP est un langage de script largement utilisé dans le domaine du développement Web. En PHP, nous rencontrons souvent des situations où des tableaux doivent être traités. Par exemple, étant donné un tableau, il est nécessaire de calculer le produit des éléments restants après avoir supprimé l'élément actuel. Cet article explique comment utiliser PHP pour implémenter le tableau de produits après avoir supprimé l'élément actuel.
1. Idée originale :
Nous pouvons utiliser deux boucles pour compléter cette exigence :
- La boucle externe traverse chaque élément
- La boucle interne calcule le produit d'éléments autres que l'élément actuellement traversé
Cependant, le La complexité temporelle de cette méthode est O(n^2). Lorsqu'il y a trop d'éléments du tableau, le temps d'exécution du programme augmentera considérablement. Par conséquent, nous devons changer notre façon de penser pour améliorer l’efficacité des algorithmes.
2. Idée d'optimisation :
Nous pouvons d'abord calculer le produit du tableau entier, puis diviser le produit du tableau entier par l'élément actuel en fonction de l'élément actuel pour obtenir le produit après avoir supprimé l'élément actuel.
Cependant, cette méthode aura des problèmes lorsque l'élément actuel est 0, car diviser par 0 n'a aucun sens. Par conséquent, nous devons gérer le cas où l’élément actuel est 0.
3. Code complet :
Le code PHP complet est donné ci-dessous :
function productExceptSelf($nums) { $length = count($nums); if ($length == 0) { return array(); } elseif ($length == 1) { return array(0); } $prod = 1; $zeroCount = 0; for ($i = 0; $i < $length; $i++) { if ($nums[$i] == 0) { $zeroCount++; if ($zeroCount > 1) { return array_fill(0, $length, 0); } continue; } $prod *= $nums[$i]; } $res = array(); for ($i = 0; $i < $length; $i++) { if ($zeroCount == 1 && $nums[$i] != 0) { $res[] = 0; continue; } if ($zeroCount > 1) { $res[] = 0; continue; } $res[] = $nums[$i] == 0 ? $prod : $prod / $nums[$i]; } return $res; }
4. Analyse du code :
Le code ci-dessus adopte l'idée suivante : Tout d'abord, scannez l'ensemble du tableau et calculez le produit des éléments non nuls. dans le tableau. En même temps, enregistrez le nombre de 0 dans le tableau. Deuxièmement, l'ensemble du tableau est analysé et pour chaque élément, le résultat final est calculé sur la base du produit total ci-dessus et du nombre de 0.
Parmi eux, si l'élément actuel est 0, un traitement spécial est adopté. Si le nombre de 0 dans le tableau est supérieur à 1, un tableau dans lequel tous les éléments sont 0 est directement renvoyé, sinon le produit des éléments courants est 0.
5. Cas de test :
Voici plusieurs ensembles de données de test :
$nums = [1, 2, 3, 4];
echo implode(",", productExceptSelf($nums)); Sortie" 24,12,8,6"
$nums = [0, 2, 3, 4];
echo implode(",", productExceptSelf($nums)); // Sortie "24,0,0, 0"
$nums = [1, 0, 3, 4];
echo implode(",", productExceptSelf($nums)); // Sortie "0,12,0,0"
$nums = [ 1, 0, 3, 0];
echo implode(",", productExceptSelf($nums)); // Sortie "0,0,0,0"
6. PHP pour implémenter la suppression Le tableau de produits après l'élément actuel. Grâce à des algorithmes d'optimisation, la complexité temporelle du programme peut être efficacement réduite et l'efficacité d'exécution du programme peut être améliorée. Dans le développement réel, nous devons choisir l'algorithme optimal pour traiter les tableaux en fonction de circonstances spécifiques.
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

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.

Undress AI Tool
Images de déshabillage gratuites

Clothoff.io
Dissolvant de vêtements AI

AI Hentai Generator
Générez AI Hentai gratuitement.

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)

Sujets chauds

Cet article examine les normes de codage PHP actuelles et les meilleures pratiques, en se concentrant sur les recommandations PSR (PSR-1, PSR-2, PSR-4, PSR-12). Il met l'accent

Cet article détaille la mise en œuvre des files d'attente de messages en PHP à l'aide de RabbitMQ et Redis. Il compare leurs architectures (AMQP vs en mémoire), les fonctionnalités et les mécanismes de fiabilité (confirmations, transactions, persistance). Meilleures pratiques de conception, erreur

Cet article détaille l'installation et le dépannage des extensions de PHP, en se concentrant sur PECL. Il couvre les étapes d'installation (trouver, télécharger / compilation, activer, redémarrer le serveur), dépannage des techniques (vérification des journaux, vérification de l'installation,

Cet article explique l'API de réflexion de PHP, permettant l'inspection d'exécution et la manipulation des classes, des méthodes et des propriétés. Il détaille les cas d'utilisation courants (génération de documentation, ORMS, injection de dépendance) et prévient contre la performance Overhea

La compilation JIT de PHP 8 améliore les performances en compilant le code fréquemment exécuté en code machine, bénéficiant aux applications avec des calculs lourds et en réduisant les temps d'exécution.

Cet article explore les stratégies pour rester à jour dans l'écosystème PHP. Il met l'accent sur l'utilisation des canaux officiels, des forums communautaires, des conférences et des contributions open source. L'auteur met en évidence les meilleures ressources pour apprendre de nouvelles fonctionnalités et un

Cet article explore l'exécution des tâches asynchrones en PHP pour améliorer la réactivité des applications Web. Il détaille des méthodes comme les files d'attente de messages, les cadres asynchrones (Reactphp, Swoole) et les processus de fond, mettant l'accent sur les meilleures pratiques pour Efficien

Cet article aborde l'optimisation de la mémoire PHP. Il détaille des techniques comme l'utilisation de structures de données appropriées, d'éviter la création d'objets inutile et d'utiliser des algorithmes efficaces. Sources de fuite de mémoire communes (par exemple, connexions non clôturées, V global
