小米技术社区
小米技术社区管理员 关于小米

27岁,山西运城人,职业电商经理人,前端开发工作者,从事过网站建设、网络推广、SEO、SEM、信息流推广、二类电商、网络运维、软件开发,等相关电商工作,经验较为丰富,小米技术社区致力于为广大从事Web前端开发的人员提供一些力所能及的引导和帮助 ...[更多]

E-mail:mzze@163.com

Q Q:32362389

W X:xiaomi168527

小米技术社区大牛王飞 关于王飞

27岁,山西运城人,职业电商经理人,网络工程师兼运维,从事过运营商网络建设,企业网络建设、优化。数据中心网络维护等通过,经验丰富,座右铭:当自己休息的时候,别忘了别人还在奔跑。 ...[更多]

E-mail:wf_live@126.com

Q Q:3940019

微博:王小贱ss

小米技术社区设计小艳 关于小艳

大于花一样的年龄,河南郑州是我家,2010年在北京接触团购网,2011年进入天猫淘宝一待就是四年,如今已经将设计走向国际化(ps:误打误撞开始进入阿里巴巴国际站的设计,嘿嘿)五年电商设计,丰富经验,从事过天猫淘宝阿里各项设计,店铺运营,产品拍摄;我将我的经历与您分享是我的快乐!座右铭:越努力越幸运! ...[更多]

E-mail:97157726@qq.com

Q Q:97157726

标签云
精品推荐
您的位置:首页 > 后端编程 > PHP > PHP基础

PHP的递归和使用注意事项

分类: PHP基础24个赞

要点:

(1)递归就是函数内部自己调用自己

(2)递归有两个元素,一个是递归点(从什么地方递归),第二递归出口

(3)递归尽量少用,因为递归需要用到现场保护,现场保护是需要消耗资源的

拓展阅读:JavaScript递归的概念、常用环境、递归注意事项


递归demo1:递归写出输出9 8 7 6 .....

<?php
function printer($num) {
    echo $num,'&nbsp;';
    if($num==1) //递归出口
        return;
    printer($num-1);    //递归点
}
printer(9); //9 8 7 6 5 4 3 2 1

递归demo2:从1加到100

function cal($num) {
    if($num==1)
        return 1;
    return $num+cal($num-1);
}
echo cal(100);
//分析
/**
第$i次执行          结果
cal(100)            100+cal(99)
=                   100+99+cal(98)
=                   100+99+98+cal(97)
=                   100+99+98+++++cal(1)
=                   100+99+98++++1
*/


递归demo3:打印前10个斐波那契数列

//打印第5个斐波那契数
function fbnq($n) {
    if($n==1 || $n==2)
        return 1;
    return fbnq($n-1)+fbnq($n-2); //第n个斐波那契数等于前两个数之和
}
echo fbnq(5),'<br>';
/**
*分析:
fbnq(5) =fbnq(4)+fbnq(3)
        =fbnq(3)*2+fbnq(2)
        =(fbnq(2)+fbnq(1))*2+fbnq(2)
        =(1+1)*2+1
        =5
*/
//打印前10个斐波那契数
for($i=1;$i<=10;$i++)
    echo fbnq($i),'&nbsp;';   //1 1 2 3 5 8 13 21 34 55


小米技术社区

本站内容均为小米原创,转载请注明出处:小米技术社区>> PHP的递归和使用注意事项