php递归简单例子,PHP中递归的实现实例详解

递归是一种函数调用自身(直接或间接)的一种机制,这种强大的思想可以把某些复杂的概念变得极为简单。这篇文章主要介绍了PHP中递归的实现实例详解,需要的朋友可以参考下

递归的定义

递归(http:/en.wikipedia.org/wiki/Recursive)是一种函数调用自身(直接或间接)的一种机制,这种强大的思想可以把某些复杂的概念变得极为简单。在计算机科学之外,尤其是在数学中,递归的概念屡见不鲜。例如:最常用于递归讲解的斐波那契数列便是一个极为典型的例子,而其他的例如阶层(n!)也可以转化为递归的定义(n! = n*(n-1)!).即使是在现实生活中,递归的思想也是随处可见:例如,由于学业问题你需要校长盖章,然而校长却说“只有教导主任盖章了我才会盖章”,当你找到教导主任,教导主任又说:“只有系主任盖章了我才会盖章”...直到你最终找到班主任,在得到班主任豪爽的盖章之后,你要依次返回到系主任、教导主任、最后得到校长的盖章,过程如下:

c6583934a84e6639f8f56f35cf04d92d.png

递归函数是一种调用自己的函数。写递归函数时要小心,因为可能会无穷递归下去。必须确保有充分的方法来终止递归。

一:使用 参数引用 完成递归函数。操作的是同一块内存地址。<?php

$i=1;

function test(&$i) {

echo $i;

$i++;

if ($i 

test($i);

}

}

test($i);// 输出123456789

test ( $i );// 输出10

?>

二:使用 全局变量 完成递归函数。

在函数域内部用 global 语句导入的一个真正的全局变量实际上是建立了一个到全局变量的引用。例子中,test()函数内部的 $i 实际上只是程序第一行中($i = 1;)的变量 $i 的一个应用;<?php

$i = 1 ;

function test () {

global $i ;

echo $i ;

$i++;

if ($i <10 ) {

test();

}

}

test();// 输出123456789

test ();// 输出10

?>

三:使用 静态变量 完成递归函数。

static的作用:仅在第一次调用函数的时候对变量进行初始化,并且保留变量值。<?php

function test () {

static $i = 1 ;

echo $i ;

$i ++;

if ( $i 

test ();

}

$i --;// 在每一层递归结束时自减,这一句可以帮助理解递归函数的执行过程

}

test();// 输出123456789

test();// 输出123456789

?>

例1. 使用全局变量的情况 递归遍历文件夹下的所有文件<?php

function getFiles($dir){

global $arr;

if(is_dir($dir)){

$hadle = @opendir($dir);

while($file=readdir($hadle) ){

if(!in_array($file,array('.', '..')) ){

$dirr = $dir.'/'.$file;

if(is_dir($dirr)){

getFiles($dirr);

}else{

array_push($arr, $dirr);

}

}

}

}

}

$arr = array();

getFiles('E:/logs');

print_r($arr);

例2:使用静态变量的情况递归遍历文件夹下的所有文件<?php

function getFiles ($dir){

static $arr = array();

if(is_dir($dir)){

$hadle = opendir($dir);

while($file=readdir($hadle)){

if(!in_array($file,array('.','..')) ){

$dirr = $dir."/".$file;

if(is_dir($dirr)){

getFiles ($dirr);

}else{

array_push($arr,$dirr);

}

}

}

}

return $arr;

}

$rows= array();

$rows = getFiles ('E:/logs');

print_r($rows);

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值