Maison développement back-end tutoriel php Méthodes d'implémentation de trois fonctions récursives PHP et accumulation de nombres

Méthodes d'implémentation de trois fonctions récursives PHP et accumulation de nombres

Jun 11, 2018 am 10:48 AM
递归函数

Quelles sont les manières d'implémenter des fonctions récursives ? Comment ajouter des nombres à l'aide d'une fonction récursive ? Cet article présente principalement trois méthodes d'implémentation des fonctions récursives PHP et comment implémenter l'accumulation numérique. Les amis dans le besoin peuvent s'y référer.

Les fonctions récursives sont un type de fonction relativement courant en programmation. Sa caractéristique est que la fonction elle-même peut s'appeler, mais elle doit être jugée conditionnellement avant de s'appeler, sinon elle provoquera des appels infinis. Cet article répertorie trois méthodes d'implémentation de fonctions récursives. La première utilise des références comme paramètres, la seconde utilise des variables globales et la troisième utilise des variables statiques. La compréhension de ces problèmes nécessite des connaissances de base, notamment la compréhension des variables globales, des références et des variables statiques. Il faut également comprendre leur champ d’action. Plus de bêtises ici, veuillez voir ci-dessous pour une introduction détaillée.

La première méthode : utiliser des références comme paramètres

Que les références soient des paramètres ou non, vous devez d'abord comprendre ce qu'est une référence ? Une référence signifie simplement que deux variables portant des noms différents pointent vers la même adresse de stockage. À l'origine, chaque variable avait sa propre adresse de stockage, et l'affectation et la suppression se déroulaient selon leur propre chemin.

D'accord maintenant, les deux variables partagent une adresse de stockage. $a=&$b; . Ce que cela signifie en réalité, c'est que $a doit partager une chambre avec $b quelle que soit son adresse de stockage d'origine. Par conséquent, toute modification de la valeur de l’adresse stockée affectera les deux valeurs. ​

Les fonctions font à l'origine leur propre travail, même s'il s'agit de fonctions portant le même nom. Les fonctions récursives envisagent de prendre des références comme paramètres et de devenir un pont pour former un partage de données entre deux fonctions. Bien que les deux fonctions semblent fonctionner sur des adresses différentes, elles opèrent en réalité sur la même adresse mémoire.

Le code est le suivant :

function test($a=0,&$result=array()){
$a++;
if ($a<10) {
    $result[]=$a;
    test($a,$result);
}
echo $a;
return $result;
}
Copier après la connexion

L'exemple ci-dessus est très simple. Utilisez a<10 comme condition de jugement. Si la condition est vraie, attribuez-la. a à result[] ; Passez la référence du résultat dans la fonction, et le a généré par chaque récursion sera ajouté au tableau de résultats result. Par conséquent, le tableau $result généré dans cet exemple est Array ( [0] => 1 [1] => 2 [2] => 3 [3] => 4 [4 ] => 5 [5] => 6 [6] => 7 [7] =>

Ce qui est plus intéressant dans cet exemple, c'est la valeur de echo a . Je crois que beaucoup de gens pensent que c'est 12345678910, mais en réalité ce n'est pas le cas, c'est 1098765432. Pourquoi? Parce que la fonction a effectué la récursion de fonction suivante avant d'exécuter echo a.

L'exécution réelle de echo a se produit lorsque a<10 les conditions ne sont pas remplies, echo a, renvoie résultat,Pour la couche supérieure, après avoir exécuté la fonction récursive, commencez à exécuter le echo $a de cette couche, et ainsi de suite.

Deuxième méthode : utilisez des variables globales

Utilisez des variables globales pour compléter des fonctions récursives. Veuillez vous assurer de bien comprendre ce que sont les variables globales . globalDéclarer des variables dans une fonction n'est rien de plus qu'une référence à une variable externe du même nom. La portée de la variable est toujours dans la portée de cette fonction. Changer les valeurs de ces variables modifiera naturellement les valeurs des variables externes du même nom. Mais une fois & utilisé, la variable du même nom n'est plus une référence du même nom. Il n'est pas nécessaire de comprendre un niveau aussi profond pour utiliser des variables globales pour implémenter des fonctions récursives. Vous pouvez comprendre les fonctions récursives naturellement en conservant la vue originale des variables globales.

Le code est le suivant :

function test($a=0,$result=array()){
    global $result;
    $a++;
    if ($a<10) {
        $result[]=$a;
        test($a,$result);
    }
    return $result;
}
Copier après la connexion

La troisième méthode : utiliser des variables statiques

On voit souvent des static< dans les classes 🎜>, Aujourd'hui nous l'utilisons dans des fonctions récursives. N'oubliez pas le rôle du statique : initialisez la variable uniquement la première fois que la fonction est appelée et conservez la valeur de la variable.

 

Par exemple :

Le code est le suivant :

function test(){
static $count=0;
echo $count;
$count++;
}
test();
test();
test();
test();
test();
  
Copier après la connexion
Quel est le résultat d'exécution de ce code ? Est-ce

00000 ? Certainement pas. Il s’agit du 01234. Tout d'abord, appelez test(), static pour la première fois pour initialiser $count Après chaque exécution, la valeur de $count sera conservée et ne le sera pas. être répété. L'initialisation équivaut à ignorer directement la phrase static $count=0;.

Par conséquent, l'effet de l'application de statique à une fonction récursive peut être imaginé. Utilisez

static pour initialiser les variables qui doivent être utilisées comme "ponts" entre les fonctions récursives. Chaque récursion conservera la valeur de la "variable de pont".

Le code est le suivant :

function test($a=0){
    static $result=array();
    $a++;
    if ($a<10) {
        $result[]=$a;
        test($a);
    }
    return $result;
}
Copier après la connexion

Résumé

La fonction dite récursive, l'accent est mis sur la façon de gérer l'appel de fonction lui-même et comment garantir ce qui est nécessaire Les résultats peuvent être raisonnablement « transmis » entre fonctions. Bien sûr, il existe également des fonctions récursives qui ne nécessitent pas de transfert de valeurs entre fonctions, par exemple :

.

function test($a=0){
    $a++;
    if ($a<10) {
        echo $a;
        test($a);
    }
}
Copier après la connexion

Utilisons un morceau de code pour démontrer comment PHP utilise des fonctions récursives pour implémenter la méthode d'accumulation numérique.

Le code est le suivant :

<?php
function summation ($count) {
   if ($count != 0) :
     return $count + summation($count-1);
   endif;
}
$sum = summation(10);
print "Summation = $sum";
?>
Copier après la connexion

         面对php递归函数,不必要伤脑筋,深入的理解变量引用相关知识对解决此类问题很有帮助,以上内容就是php递归函数三种实现方法及如何实现数字累加的全部内容,希望对大家今后的学习有所帮助。

以上就是本文的全部内容,希望对大家的学习有所帮助,更多相关内容请关注PHP中文网!

相关推荐:

thinkPHP实现联动菜单的功能

php合并数组并保留键值的实现方法

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)
1 Il y a quelques mois By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Meilleurs paramètres graphiques
1 Il y a quelques mois By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Comment réparer l'audio si vous n'entendez personne
1 Il y a quelques mois By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Commandes de chat et comment les utiliser
1 Il y a quelques mois 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)

Quelles sont les techniques d'optimisation des fonctions récursives C++ ? Quelles sont les techniques d'optimisation des fonctions récursives C++ ? Apr 17, 2024 pm 12:24 PM

Pour optimiser les performances des fonctions récursives, vous pouvez utiliser les techniques suivantes : Utiliser la récursion de queue : placez des appels récursifs à la fin de la fonction pour éviter une surcharge récursive. Mémorisation : stockez les résultats calculés pour éviter les calculs répétés. Méthode diviser pour mieux régner : décomposer le problème et résoudre les sous-problèmes de manière récursive pour améliorer l'efficacité.

Comment résoudre l'erreur de trop de fonctions imbriquées dans le code Python ? Comment résoudre l'erreur de trop de fonctions imbriquées dans le code Python ? Jun 25, 2023 pm 12:35 PM

Python est un langage de programmation très puissant et de nombreux programmeurs choisissent Python comme langage de programmation principal. Cependant, trop de fonctions imbriquées dans le code peuvent rendre le programme difficile à maintenir et à comprendre. Cet article explique comment résoudre l'erreur d'imbrication excessive des fonctions dans le code Python. Une brève introduction à l'imbrication de fonctions L'imbrication de fonctions fait référence au processus de définition d'une autre fonction dans le corps d'une fonction. L'imbrication de fonctions peut rendre la structure du programme plus claire et le code plus facile à lire et à maintenir. Cependant, un trop grand nombre de fonctions imbriquées peut conduire à une structure de code trop complexe.

Application des fonctions récursives C++ dans les algorithmes de recherche ? Application des fonctions récursives C++ dans les algorithmes de recherche ? Apr 17, 2024 pm 04:30 PM

Les fonctions récursives sont utilisées dans les algorithmes de recherche pour explorer des structures de données arborescentes. La recherche en profondeur utilise une pile pour explorer les nœuds, tandis que la recherche en largeur utilise une file d'attente pour parcourir couche par couche. Dans des applications pratiques, telles que la recherche de fichiers, les fonctions récursives peuvent être utilisées pour rechercher un fichier donné dans un répertoire spécifié.

Quelles sont les conditions de sortie d'une fonction récursive en C++ ? Quelles sont les conditions de sortie d'une fonction récursive en C++ ? Apr 17, 2024 am 11:33 AM

Les conditions de sortie des fonctions récursives C++ incluent : Conditions de base : vérifiez si la fonction atteint un état qui peut renvoyer directement des résultats, en jugeant généralement si une certaine condition ou valeur de paramètre atteint le seuil. Condition de fin de récursion : Alternative ou en plus à la condition de base, garantissant que la fonction s'arrête après un certain nombre d'appels récursifs, en suivant la profondeur de récursion ou en définissant une limite maximale de profondeur de récursion.

Application de la fonction récursive C++ dans l'algorithme de tri ? Application de la fonction récursive C++ dans l'algorithme de tri ? Apr 17, 2024 am 11:06 AM

L'application de fonctions récursives dans les algorithmes de tri en C++ Les algorithmes de tri par insertion et de tri par fusion implémentés par les fonctions récursives peuvent décomposer des problèmes complexes en sous-problèmes plus petits et les résoudre efficacement grâce à des appels récursifs. Tri par insertion : trie un tableau en insérant des éléments un par un. Tri par fusion : divisez pour mieux régner, divisez le tableau et triez récursivement les sous-tableaux, et enfin fusionnez les sous-tableaux triés.

Comment implémenter la stratégie d'optimisation de la récursion de queue des fonctions récursives C++ ? Comment implémenter la stratégie d'optimisation de la récursion de queue des fonctions récursives C++ ? Apr 17, 2024 pm 02:42 PM

La stratégie d'optimisation de la récursion de queue réduit efficacement la profondeur de la pile des appels de fonction et empêche le débordement de pile en convertissant les appels récursifs de queue en boucles. Les stratégies d'optimisation incluent : Détecter la récursion de queue : vérifiez s'il existe des appels récursifs de queue dans la fonction. Convertissez les fonctions en boucles : utilisez des boucles au lieu d'appels récursifs et maintenez une pile pour enregistrer l'état intermédiaire.

Comment implémenter factorielle à l'aide de fonctions récursives en langage Go ? Comment implémenter factorielle à l'aide de fonctions récursives en langage Go ? Jul 31, 2023 pm 08:31 PM

Comment implémenter factorielle à l'aide de fonctions récursives en langage Go ? Factorielle est un calcul courant en mathématiques qui multiplie un entier non négatif n par tous les entiers positifs plus petits que lui, jusqu'à 1. Par exemple, la factorielle de 5 peut être exprimée sous la forme 5 !, calculée comme suit : 54 321 = 120. En programmation informatique, nous utilisons souvent des fonctions récursives pour mettre en œuvre des calculs factoriels. Tout d’abord, nous devons comprendre le concept de fonctions récursives. Une fonction récursive fait référence au processus d'appel de la fonction elle-même dans le cadre de la définition de la fonction. Lors de la résolution d'un problème, une fonction récursive sera continuellement

Programme C pour lister tous les fichiers et sous-répertoires d'un répertoire Programme C pour lister tous les fichiers et sous-répertoires d'un répertoire Aug 25, 2023 pm 10:09 PM

Ici, nous avons un répertoire. Notre tâche est de créer un programme C pour lister tous les fichiers et sous-répertoires d'un répertoire. Un répertoire est un lieu/zone/emplacement où un ensemble de fichiers sera stocké. Un sous-répertoire est un répertoire situé dans le répertoire racine, qui, à son tour, peut contenir un autre sous-répertoire. En langage de programmation C, vous pouvez facilement répertorier tous les fichiers et sous-répertoires d’un répertoire. Le programme suivant montre comment répertorier tous les fichiers et sous-répertoires d'un répertoire. //Exemple de programme C pour lister tous les fichiers et sous-répertoires du répertoire Démonstration en direct #include<stdio.h>#include<dirent.h>intmain(void){ &am

See all articles