php递归使用示例(php递归函数)


Posted in PHP onFebruary 14, 2014
//递归获得角色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();
}

php的递归函数用法

一个函数在它的函数体内调用它自身称为递归调用。这种函数称为递归函数。这对于程序员来说,通常有很高的实用价值,常用来将复杂的问题分解为简单的并相同的情况,反复做这种处理直到问题解决。

用递归函数与不用递归函数的区别

示例一:使用静态变量

function test(){
  static $dig=0;
  if($dig++<10){
    echo $dig;
    test();
  }
}
test();//12345678910

示例二:使用递归函数和循环实现字符串逆转排列

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

递归函数很多时候我们可以循环替代,建议当我们不能用循环替代时再用,因为用循环我们更容易理解,更不容易出错。

php递归函数 php支付递归函数,递归函数就是调用自己本身,这些函数特别适用于浏览动态数据结构,例如树和列表。
几乎没有web应用程序要求使用复杂的数据结构

<?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);
}
}

这个程序清单中实现两个函数,这两个函数都可以相反的顺序打印字符串的内容
函数reversr_r是通过递归实现的,而函数reverse_i()是通过循环实现的

PHP 相关文章推荐
PHP语法速查表
Dec 06 PHP
php cout&amp;lt;&amp;lt;的一点看法
Jan 24 PHP
php 处理上百万条的数据库如何提高处理查询速度
Feb 08 PHP
PHP英文字母大小写转换函数小结
May 03 PHP
PHP实现把文本中的URL转换为链接的auolink()函数分享
Jul 29 PHP
php实现mysql事务处理的方法
Dec 25 PHP
php+mysql删除指定编号员工信息的方法
Jan 14 PHP
php数组去除空值函数分享
Feb 02 PHP
深入剖析PHP中printf()函数格式化使用
May 23 PHP
PHP微信开发之文本自动回复
Jun 23 PHP
thinkphp分页集成实例
Jul 24 PHP
PHP排序算法之基数排序(Radix Sort)实例详解
Apr 21 PHP
php根据isbn书号查询amazon网站上的图书信息的示例
Feb 13 #PHP
使用php记录用户通过搜索引擎进网站的关键词
Feb 13 #PHP
php中simplexml_load_string使用实例分享
Feb 13 #PHP
使用php显示搜索引擎来的关键词
Feb 13 #PHP
php根据日期判断星座的函数分享
Feb 13 #PHP
php的hash算法介绍
Feb 13 #PHP
php去除字符串换行符示例分享
Feb 13 #PHP
You might like
php新浪微博登录接口用法实例
2014/12/23 PHP
PHP开发注意事项总结
2015/02/04 PHP
twig模板常用语句实例小结
2016/02/04 PHP
PHP使用SOAP扩展实现WebService的方法
2016/04/01 PHP
PHP错误处理函数
2016/04/03 PHP
php获取客户端IP及URL的方法示例
2017/02/03 PHP
PHP进阶学习之反射基本概念与用法分析
2019/06/18 PHP
一个多次搜索+多次传值的解决方案
2007/01/20 Javascript
js字符编码函数区别分析
2008/06/05 Javascript
为jquery.ui.dialog 增加“在当前鼠标位置打开”的功能
2009/11/24 Javascript
js indexOf()定义和用法
2012/10/21 Javascript
JavaScript实战之菜单特效
2016/08/16 Javascript
Javascript 获取鼠标当前的位置实现方法
2016/10/27 Javascript
vue2.0全局组件之pdf详解
2017/06/26 Javascript
React Native日期时间选择组件的示例代码
2018/04/27 Javascript
浅谈vue方法内的方法使用this的问题
2018/09/15 Javascript
手把手教你 CKEDITOR 4 扩展插件制作
2019/06/18 Javascript
Python中在for循环中嵌套使用if和else语句的技巧
2016/06/20 Python
对python3新增的byte类型详解
2018/12/04 Python
python实现桌面托盘气泡提示
2019/07/29 Python
Keras在训练期间可视化训练误差和测试误差实例
2020/06/16 Python
python import 上级目录的导入
2020/11/03 Python
css3背景_动力节点Java学院整理
2017/07/11 HTML / CSS
CSS3 RGBA色彩模式使用实例讲解
2016/04/26 HTML / CSS
茵宝(Umbro)英国官方商店:英国足球服装生产商
2016/12/29 全球购物
自然健康的概念:Natural Healthy Concepts
2020/01/26 全球购物
40岁生日感言
2014/02/15 职场文书
挂职自我鉴定
2014/02/26 职场文书
爱心捐书活动总结
2014/07/05 职场文书
学生党员一帮一活动总结
2014/07/08 职场文书
法人委托书的范本格式
2014/09/11 职场文书
离婚协议书的书写要求
2014/09/17 职场文书
2014-2015学年工作总结
2014/11/27 职场文书
联谊活动总结范文
2015/05/09 职场文书
python机器学习创建基于规则聊天机器人过程示例详解
2021/11/02 Python
vue项目打包后路由错误的解决方法
2022/04/13 Vue.js