PHP递归算法就是函数调用函数了操作非常的简单了,我们下面来给各位介绍PHP递归算法及实际的一些关于递归的用法。

递归函数为自调用函数,在函数体内直接或间接自己调用自己,但需要设置自调用的条件,若满足条件,则调用函数本身,若不满足则终止本函数的自调用,然后把目前流程的主控权交回给上一层函数来执行,可能这样给大家讲解,还是很难明白,直接上例子function test ($n){

echo $n.” “;

if($n>0){

test($n-1);

}else{

echo “>”;

}

echo $n.” ”

}

test(2)

这个例子最终的输出结果是2 1 0>0 1 2

我解释下 为何输出是这样的

第一步,执行test(2),echo 2,然后因为2>0,执行test(1), 后面还有没来得及执行的echo 2

第二步,执行test(1),echo 1,然后因为1>0,执行test(0),同样后面还有没来得及执行的 echo 1

第三步,执行test(0),echo 0,执行test(0),echo 0, 此时0>0的条件不满足,不在执行test()函数,而是echo “>”,并且执行后面的 echo 0

此时函数已经不再调用自己,开始将流程的主控权交回给上一层函数来执行,也就是开始执行刚刚所有test()函数没来得及输出的最后一个echo,0的一层是1也就是输出1 1的上一层是2 也就是输出2 2没有山一层 所以呢 输出的内容就是2 1 0>0 1 2

如何考虑用PHP递归算法来解决问题

例:求s=1+2+3+4+5+6+……+n本来这个问题我们过去常用循环累加的方法。而这里如要用递归的方法,必须考虑两点:

1) 能否把问题转化成递归形式的描述;

2) 是否有递归结束的边界条件。

显然递归的两个条件都有了:

1) s(n) =s(n-1)+n

2) s(1)=1

所以源程序为:int progression(int n){

int res;

if (n=1 )res=1 else res=progression(n-1)+n;

return res;

}

中序遍历二叉树void inorder (BinTree T){

if (T){

inorder(T->lchild);

printf(“%c”,T->data);

inorder(T->rchild);

}

}

Mysql

首先我们准备一张数据表class,记录商品分类信息。表中有三个字段,id:分类编号,主键自增长;title:分类名称;pid:所属上级分类id。

class表结构:CREATE TABLE IF NOT EXISTS `class` (

`id` mediumint(6) NOT NULL AUTO_INCREMENT,

`title` varchar(30) NOT NULL,

`pid` mediumint(6) NOT NULL DEFAULT '0',

PRIMARY KEY (`id`)

) ENGINE=MyISAM DEFAULT CHARSET=utf8;

插入数据后,如图:

根据不同的需求,我们提供两种不同格式的自定义函数,一种是返回字符串,一种是返回数组,两种函数都使用了递归方法。先看返回字符串格式的函数:function get_str($id = 0) {

global $str;

$sql = "select id,title from class where pid= $id";

$result = mysql_query($sql);//查询pid的子类的分类

if($result && mysql_affected_rows()){//如果有子类

$str .= '';

while ($row = mysql_fetch_array($result)) { //循环记录集

$str .= "

" . $row['id'] . "--" . $row['title'] . ""; //构建字符串

get_str($row['id']); //调用get_str(),将记录集中的id参数传入函数中,继续查询下级

}

$str .= '';

}

return $str;

}

以上函数get_str()通过递归,不断查询下级分类,并最终返回字符串,大家可以根据项目需求修改其中的str,最终生成一个无限分级列表:include_once('connect.php'); //连接数据库,connect.php文件自己写一个啊

echo get_str(0); //输出无限级分类

效果如:

接着我们来看返回数组格式的函数,一样要使用递归:function get_array($id=0){

$sql = "select id,title from class where pid= $id";

$result = mysql_query($sql);//查询子类

$arr = array();

if($result && mysql_affected_rows()){//如果有子类

while($rows=mysql_fetch_assoc($result)){ //循环记录集

$rows['list'] = get_array($rows['id']); //调用函数,传入参数,继续查询下级

$arr[] = $rows; //组合数组

}

return $arr;

}

}

函数get_array()返回了数组,这是我们期待的,所以笔者推荐使用get_array()得到数组,这样一来,我们可以对数组进行任意操作,比如我们可以将数组转换成json格式的数据传给前端页面,前端页面可以通过解析json数据灵活展示分类信息。比如树形结构的分类列表,下拉分类列表等。include_once('connect.php'); //连接数据库

$list = get_array(0); //调用函数

print_r($list); //输出数组

如果要输出json格式的数据,则可使用:

echo json_encode($list);

本文原创发布php中文网,转载请注明出处,感谢您的尊重!

递归算法php,php递归算法经典实例相关推荐

  1. java古典兔子问题c语言,Java递归算法经典实例(经典兔子问题)

    Java递归算法经典实例(经典兔子问题) 题目:古典问题:3个月起每个月都生一对兔子,小兔子长到第三个月后每个月又生一对兔子,假如兔子都不死,问每个月的兔子总数为多少? 分析:首先我们要明白题目的意思 ...

  2. 递归Java_Java递归算法经典实例

    原标题:Java递归算法经典实例 简单递归定义 什么叫递归?(先定义一个比较简单的说法,为了理解,不一定对) 递归:无限调用自身这个函数,每次调用总会改动一个关键变量,直到这个关键变量达到边界的时候, ...

  3. 递归算法转换为非递归算法的技巧

    递归算法转换为非递归算法的技巧 递归函数具有很好的可读性和可维护性,但是大部分情况下程序效率不如非递归函数,所以在程序设计中一般喜欢先用递归解决问题,在保证方法正确的前提下再转换为非递归函数以提高效率 ...

  4. zz 递归算法转换为非递归算法

    from:http://blog.csdn.net/Shunrei/archive/2010/06/19/5680579.aspx 递归算法实际上是一种分而治之的方法,它把复杂问题分解为简单问题来求解 ...

  5. 遍历二叉树的递归算法与非递归算法

    遍历二叉树的递归算法与非递归算法 先来看下面这棵二叉树.如图1.现在我们要对它进行先序遍历.递归思想:就是把这个大树拆分成N棵小树,每棵小树都进行一次先序遍历.再把这些遍历连合起来就是这棵树的先序遍历 ...

  6. 递归算法向非递归算法转换

    递归算法向非递归算法转换 递归算法实际上是一种分而治之的方法,它把复杂问题分解为简单问题来求解.对于某些复杂问题(例如hanio塔问题),递归算法是一种自然且合乎逻辑的解决问题的方式,但是递归算法的执 ...

  7. 递归算法与非递归算法的转化

    递归算法实际上是一种分而治之的方法,它把复杂问题分解为简单问题来求解.对于某  些复杂问题(例如 hanio塔问题),递归算法是一种自然且合乎逻辑的解决问题的方式,  但是递归算法的执行效率通常比较差 ...

  8. 递归算法转换为非递归算法

    转 自 : https://blog.csdn.net/fbz123456/article/details/50959412 递归算法实际上是一种分而治之的方法,它把复杂问题分解为简单问题来求解.对于 ...

  9. 递归算法与非递归算法比较

    转载自:https://blog.csdn.net/mhsszm/article/details/78445591 非递归效率高:递归代码写出来思路清晰,可读性强. 生成可执行文件大小应该和编译器有关 ...

  10. 计算斐波那契数列递归算法和非递归算法的比较

    对于斐波那契数列的计算是计算机算法经典问题,常见的算法有递归算法和非递归算法两种,那么它们之间的不同应该如何对比? 本文用python为例,比较两种不同算法的时间复杂度等不同 代码比较 递归算法: # ...

最新文章

  1. Data - 【转】数据分析的道与术
  2. ue 抗锯齿 渲染序列失灵_最大的锯齿形序列
  3. Proxy error: Could not proxy request /api/ from localhost:8080 to http://localhost:80
  4. SPOJ 4487. Can you answer these queries VI splay
  5. linux下如何安装charles
  6. 人力资源管理书籍排行榜,HR必读的十本书推荐
  7. dw如何制作图片自动切换效果_如何在DREAMWEAVER中做出图片切换效果?
  8. hdmi接口线_HDMI高清线注意事项
  9. vs2017 错误:当前页面的脚本发生错误
  10. 怎么在手机上取消双重认证_用手机在淘宝上怎么开网店?流程步骤详解
  11. 自动定量包装秤厂家@这雨不下了
  12. 21天减肥法反弹案例-987减肥网
  13. 停车还能360全方位影像_汽车新技术:360全景环视系统技术
  14. JAVA个人博客系统毕业设计,个人博客系统设计与实现,个人博客网页设计毕设作品
  15. K8S之ReplicaSet详解
  16. input 输入数字而且最大为10
  17. 综述:人类电生理的脑连接组学
  18. 新东方托福词汇(List 26 ~ List 30)
  19. 液体精密过滤器 不锈钢316L精密过滤器
  20. “我有技术到哪都是一样的”?年薪40W测试工程师被裁,回怼的这一番话,令人沉思

热门文章

  1. 获取 app 签名的方式汇总
  2. C语言 三角函数用法
  3. Ucinet6 + Netdraw 根据excel文件绘制网络拓扑图
  4. vb.net使用DirectX入门知识
  5. Awvs 12.x安装教程
  6. python解析nmea0183协议获取GPS定位信息
  7. C#将集合key键以ASCII码从小到大排序
  8. QT之TreeWidgetItem基本使用
  9. 入行必看、经验不足必看:财务会计需要会的那些软件工具
  10. 字体arial不支持样式regular的解决方法