function demo($n){
if($n>1){
$n=$n*demo($n-1);
}else{
return 1;
}
return $n;
}
echo demo(10);
这个程序是算的10 的阶乘
return $n 是啥意思? 是返回每一次乘的结果 然后最终都乘在一起? 谢谢
return $n啊……
首先你要理解一点,一个函数比如
CODE:
demo($n){return $n+1;}
它的意义就是,demo($n)=$n+1,你获取demo(1)的值就等于获取2
你获取demo(2)的值就等于获取3
这个你应该理解的,然后我再变化一下:
CODE:
demo($n){return $n*demo($n+1);}
这个就构成递归了
但是这个递归没有出口,永远不会结束
首先,楼主,请用模拟下程序的思维,
你调用了demo(1),程序会怎么做?
第一步,程序会进入到函数体中第一步计算 1*demo(2) 对不对?
第二步,程序又遇到了第二个函数体,即是demo(2),于是进入到demo(2)中进行2*demo(3)
第三步,程序又遇到了第三个函数体,即是demo(3),于是进入到demo(2)中进行2*demo(4)
……
永无止境
除非 你加一个边界值:
CODE:
demo($n){
if($n>2)
return 1;
return $n*demo($n+1);}
其实这就是数学方程式:
n*f(n+1),n=3
这也就是为什么方程式和方法体都叫做函数(function)的原因
于是$n=3的时候,程序体终止,回到之前的第三步,得到了demo(3)=1
然后回到了之前的第二步,得到了demo(2)=2*demo(3)=2
然后回到之前的第一步,得到了demo(1)=1*demo(2)=2
说了这么多,return的意义就在于,让你的demo()函数体具有一个可以被计算的值
于是,你的式子也可以列出和上面那个一样的数学函数来了
n*f(n-1);n1
f替换成demo有什么区别么?
递归都可以用这种数学表达式列出来,是不是清晰很多?
的确清晰很多 非常感谢 以后有不会的问题 还想请教您 !
本回答被提问者采纳