Maison >développement back-end >tutoriel php >Exemple d'utilisation de la fonction récursive php
La fonction récursive PHP est un élément indispensable dans notre développement actuel. Pour les programmeurs, la fonction récursive PHP a une grande valeur d'utilisation et peut résoudre de nombreux problèmes. Aujourd'hui, nous allons vous la présenter. Voici utilisation. exemples de fonctions récursives PHP !
Cet article présente principalement des exemples d'utilisation de la récursion PHP (fonction récursive php), notamment l'obtention récursive de l'ID de rôle chaîne , l'obtention récursive du tableau d'informations de rôle en cascade et l'obtention de l'identifiant du parent. role Pour obtenir des informations sur les sous-rôles, les amis qui en ont besoin peuvent se référer à
//递归获得角色ID字符串 function explodeRole($roleObj, &$resultStr){ if(0 < count($roleObj->childRoleObjArr)){ foreach($roleObj->childRoleObjArr as $childRoleObj){ if('' == $resultStr){ $resultStr .= "{$childRoleObj->id}"; }else{ $resultStr .= ", {$childRoleObj->id}"; } explodeRole($childRoleObj, $resultStr); } } } //递归获取级联角色信息数组 function makeRoleRelation(&$roleObjArr){ foreach($roleObjArr as $item){ $item->childRoleObjArr = getRoleObjArrByParentId($item->id); if(0 < count($item->childRoleObjArr)){ makeRoleRelation($item->childRoleObjArr); } } } //通过父角色的id获取子角色信息 function getRoleObjArrByParentId($parentid){ $operCOGPSTRTSysRole = new COGPSTRTSysRole(); $operCOGPSTRTSysRole->setColumn($operCOGPSTRTSysRole->getAllColumn()); $operCOGPSTRTSysRole->setWhere("parentroleid={$parentid}"); $roleObjArr = $operCOGPSTRTSysRole->convResult2ObjArr($operCOGPSTRTSysRole->selectTable()); return isset($roleObjArr)?$roleObjArr:array(); }
Utilisation récursive des fonctions PHP
Une fonction qui s'appelle elle-même dans son corps de fonction est appelée un appel récursif. Ce type de fonction est appelé fonction récursive. Cela a généralement une grande valeur pratique pour les programmeurs et est souvent utilisé pour décomposer des problèmes complexes en situations simples et identiques, et cela à plusieurs reprises jusqu'à ce que le problème soit résolu.
La différence entre utiliser des fonctions récursives et ne pas utiliser de fonctions récursives
Exemple 1 : Utiliser des variables statiques
function test(){ static $dig=0; if($dig++<10){ echo $dig; test(); } } test();//12345678910
Exemple 2 : L'utilisation de fonctions récursives et de boucles réalise un arrangement inverse de chaînes
function unreverse($str){ for($i=1;$i<=strlen($str);$i++){ echo substr($str,-$i,1); } } unreverse("abcdefg");//gfedcbc function reverse($str){ if(strlen($str)>0){ reverse(substr($str,1)); echo substr($str,0,1); return; } } reverse("abcdefg");//gfedcbc
Les fonctions récursives peuvent souvent être remplacées par des boucles. Il est recommandé de les utiliser lorsque nous ne pouvons pas les remplacer par des boucles, car elles sont plus faciles à comprendre et moins sujettes. aux erreurs avec les boucles.
Fonction récursive php PHP paie des fonctions récursives. Les fonctions récursives s'appellent elles-mêmes. Ces fonctions sont particulièrement adaptées à la navigation dans des structures de données dynamiques, telles que des arbres et des listes.
Presque aucune application Web ne nécessite l'utilisation de structures de données complexes
<?php function reversr_r($str) { if (strlen($str)>0) reverse_r(substr($str,1)); echo substr($str,0,1); return; } ?> <?php function reverse_i($str) { for($i=1;$i<=strlen($str);$i++) { echo substr($str,-$i,1); } }
Cette liste de programmes implémente deux fonctions, qui peuvent toutes deux imprimer le contenu d'une chaîne dans l'ordre inverse
La fonction reversr_r est implémentée par récursion, tandis que la fonction reverse_i() est implémentée via des boucles
Résumé :
Cet article utilise deux exemples pour utiliser PHP récursif Les fonctions sont analysées. Les amis peuvent avoir une compréhension substantielle des fonctions récursives PHP grâce à cet article !
Recommandations associées :
Qu'est-ce que la fonction récursive PHP et un exemple d'explication simple
Connaissez-vous les précautions d'utilisation du retour dans les fonctions récursives 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!