① php 递归函数
$hg-1 没有改变$hg的值。而$hg--或者--$hg都改变了$hg的值。
首先分析 $hg--; 这是先用$hg再减1。也就是说每次都用的是 gogo(3).形成了死循环。
然后分析 --$hg; 这是先减1再用。
第1次:gogo(3) = 2*(gogo(2)); //
第2次:gogo(2) = 1*(gogo(1));
第3次:gogo(1) = 0*(gogo(0)) = 0*1 = 0;
② 解释一下php中递归函数的作用
在函数中 echo 是直接输入 echo 后面的程序还会被继续执行\r\nreturn 是这个函数的返回值 在函数内 一但程序执行到 return 下面的程序就会结束。希望对你又帮助
③ 如何理解php中的递归函数 (详细讲解)
递归其实就是“一个函数的自调用”
在这个“自调用”的过程中,必须要有一个变化的“参数”,当这个“参数”达到你的期望值的时候,终止该“自调用”过程
拿楼主的程序来说
demo($n)内部又有调用demo($n-1),构成了“自调用”
且,$n又有一个“期望值”,即是$n>1,不满足此条件时,该自调用终止
即是说,最后一个执行的demo是demo($n9-1),其中$n9=2,然后返回为1(因为执行了return 1)
则$n9*demo($n9-1)即等于 2*demo(2-1),又等于2*1=2;
则$n8*demo($n8-1)即等于 3*demo(3-1),又等于3*2=6;
则$n7*demo($n7-1)即等于 4*demo(4-1),又等于4*6=24;
……
依次类推
这样想:
demo(1)是等于1,这个没有疑问吧?
然后demo(2)等于2*demo(1)=2*1=2
然后demo(3)等于3*demo(2)=3*2=6
……
一直到demo(10)
④ PHP 递归函数返回值问题
朋友,你这个函数逻辑有问题
1.
$countsort_sql
=
"SELECT
*
FROM
`{$db_table}newssort`
WHERE
`newssort_pid`
=
'$pid'";
这个的字段newssort_pid,如果第一次$pid可以查询出结果,那么下边
while($countsort_row
=
mysql_fetch_assoc($countsort_result)){
countSort($countsort_row['newssort_pid']);
}
这里的参数$countsort_row['newssort_pid']就是你第一次输入$pid,那么如果按照正常思路就永远循环
所以,我认为这里的countSort($countsort_row['newssort_pid']);中$countsort_row['newssort_pid']应该加以变化,比如+1
2.递归的判断条件if($countsort_number
>
0)
这个$countsort_number
如果有一次查询结果那么它永远是>0,这是不对的。
修改函数如下,希望对你有所帮助。
function
countSort($pid)
{
global
$countsort_number;
$countsort_sql
=
"SELECT
*
FROM
`{$db_table}newssort`
WHERE
`newssort_pid`
=
'$pid'";
$countsort_result
=
mysql_query($countsort_sql)
or
die('数据库查询失败,请与管理员联系!');
$num=mysql_num_rows($countsort_result);
$countsort_number
+=$num;
if(
$num
>
0)
{
while($countsort_row
=
mysql_fetch_assoc($countsort_result)){
countSort(++$countsort_row['newssort_pid']);
}
mysql_free_result($countsort_result);
}
else
$abc=
$countsort_number;
}
⑤ php递归函数
很简单,每个demo函数不考虑中间的自身递归,都输出同样的2个数$num.,这两个数其实就是首尾对称的的两个数,
⑥ PHP怎么递归
下面我举一个其他的例子,虽然不是族谱,但是原理都是一样的。
在一些复杂的系统中,要求对信息栏目进行无限级的分类,以增强系统的灵活性。那么PHP是如何实现无限级分类的呢?我们在本文中使用递归算法并结合mysql数据表实现无限级分类。
递归,简单的说就是一段程序代码的重复调用,当把代码写到一个自定义函数中,将参数等变量保存,函数中重复调用函数,直到达到某个条件才跳出,返回相应的数据。
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;
插入数据后,如图:
如果要输出json格式的数据,则可使用:
echo json_encode($list);
⑦ 什么是php递归函数及简单实例讲解
递归其实就是“一个函数的自调用” 在这个“自调用”的过程中,必须要有一个变化的“参数”,当这个“参数”达到你的期望值的时候,终止该“自调用”过程 拿楼主的程序来说 demo($n)内部又有调用demo($n-1),构成了“自调用” 且,$n又有一个“期望值
⑧ php中用递归函数计算出16的4次方
这个实际上是算组合数;
其中包含的有递推公式:comm(n,k)=comm(n-1,k)+comm(n-1,k-1);
comm(n,0)=1,comm(n,n)=1为递归初始条件。
递推公式和初始条件就是组合数的性质,相当于在算组合数,你把他逐步分解往回推就行了。
其实就我的理解,递归就是一种堆栈的形式,而且是一种循环。
如果还有不理解的可以问我。
⑨ 谁帮我解释一下这个PHP递归函数的流程。
$arr=array() 是定义一维数组的意思,$arr[] 中括号内 代表的是键值(即数组下标) , $arr[]整体代表数组中键值所对应的值;foreach 的遍历数组$node , $v是键值 ;在你这里$node 应该是二维数组,遍历完了 $v为一维数组,在判断一维数组下标 为 pid所指向的值是否 等于$pid,如果等于;执行if语句内的递归函数,并赋值给 一维数组下标为 child 的值;递归调用 node_merge函数,层层递归调用自身,直到不符合if条件,运行$v数组中的值赋值给$arr数组;最后返回一维数组