php递归实例
递归做为一种算法在程序设计语言中广泛应用。 一个过程或函数在其定义或说明中有直接或间接调用自身的一种方法,它通常把一个大型复杂的问题层层转化为一个与原问题相似的规模较小的问题来求解,递归策略只需少量的程序就可描述出解题过程所需要的多次重复计算,大大地减少了程序的代码量。
下面举4个递归的实例:
<?php          /*         递归的实例         1、统计数组元素个数       php也可以直接使用count($arr,1) 来计算多维数组的元素的个数         2、统计文件和文件夹数量         3、删除文件或文件夹         用到的系统函数:file_exists()检查目录或者文件是否存在 unlink()删除文件 rmdir()删除目录         4、无限极分类的排序     */     /**     * 递归共计数组元素个数     * @param array $arr 统计的数组     * @return boolean|int  如果失败返回false,成功返回数组的元素个数     */     function conarr($arr){         function funtmp($arr,$sum=0){             if(is_array($arr)){                 $sum=count($arr);             }else{                 return count($arr);             }             foreach($arr as $k=> $v){ if(is_array($v)){ $sum += funtmp($v,$sum); } } return $sum; } return funtmp($arr); } // $arr = array(1,2,3,4,array(1,2,3,array(0,3))); // echo conarr($arr).'<br>'; // echo count($arr,1); /** * 递归统计指定目录的子文件的个数和文件夹个数 * @param $dirname string 目录路径 * @return array|boolean 返回包含子文件个数和文件夹个数的数组,失败返回false */ function condir($dirname,$data = array('dirnum'=>0,'filenum'=>0)){ if(!is_dir($dirname)){ return false; } $dir = opendir($dirname); //打开句柄 readdir($dir);//读取点 readdir($dir);//读取点 while($filename = readdir($dir)){ $newfile = $dirname.'/'.$filename;//拼接子文件名 if(is_dir($newfile)){ $data['dirnum']++; $data['dirnum']+=condir($newfile)['dirnum']; $data['filenum']+=condir($newfile)['filenum']; }else{ $data['filenum']++; } } return $data; } //$a = condir('C:\wamp\www\test'); //var_dump($a); /** * 删除文件或者文件夹 * @param string $dirname 文件路径 * @return boolean 删除成功返回true,失败返回false */ function delDir($dirname){ if(!file_exists($dirname)){return false;} if($dir = opendir($dirname)){ while($filename = readdir($dir)){ if($filename !="."&& $filename !='..'){ $subFile = $dirname.'/'.$filename; if(is_dir($subFile)){ delDir($subFile); } if(is_file($subFile)){ unlink($subFile); } } } closedir($dir); rmdir($dirname); } if(!file_exists($dirname)){ return true; }else{ return false; } } //echo delDir('C:\wamp\www\test'); //无限极分类排序,父类后跟子类 function getlist($cate,$pid=0,$html="------",$i=0){ $i++; $list = array(); foreach($cate as $val){ if($val['pid']==$pid){ $val['html']=str_repeat($html,$i-1); $list[]=$val; $list = array_merge($list,getlist($cate,$val['id'],$html,$i)); } } return $list; } ?>
以上就介绍了php递归实例,包括了方面的内容,希望对PHP教程有兴趣的朋友有所帮助。

热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

AI Hentai Generator
免费生成ai无尽的。

热门文章

热工具

记事本++7.3.1
好用且免费的代码编辑器

SublimeText3汉化版
中文版,非常好用

禅工作室 13.0.1
功能强大的PHP集成开发环境

Dreamweaver CS6
视觉化网页开发工具

SublimeText3 Mac版
神级代码编辑软件(SublimeText3)

热门话题

C语言return的用法有:1、对于返回值类型为void的函数,可以使用return语句来提前结束函数的执行;2、对于返回值类型不为void的函数,return语句的作用是将函数的执行结果返回给调用者;3、提前结束函数的执行,在函数内部,我们可以使用return语句来提前结束函数的执行,即使函数并没有返回值。

源码:publicclassReturnFinallyDemo{publicstaticvoidmain(String[]args){System.out.println(case1());}publicstaticintcase1(){intx;try{x=1;returnx;}finally{x=3;}}}#输出上述代码的输出可以简单地得出结论:return在finally之前执行,我们来看下字节码层面上发生了什么事情。下面截取case1方法的部分字节码,并且对照源码,将每个指令的含义注释在

标题:C#中使用Array.Sort函数对数组进行排序的示例正文:在C#中,数组是一种常用的数据结构,经常需要对数组进行排序操作。C#提供了Array类,其中有Sort方法可以方便地对数组进行排序。本文将演示如何使用C#中的Array.Sort函数对数组进行排序,并提供具体的代码示例。首先,我们需要了解一下Array.Sort函数的基本用法。Array.So

在进行PHP编程时,我们常常需要对数组进行合并。PHP提供了array_merge()函数来完成数组合并的工作,不过当数组中存在相同的键时,该函数会覆盖原有的值。为了解决这个问题,PHP在语言中还提供了一个array_merge_recursive()函数,该函数可以合并数组并保留相同键的值,使得程序的设计变得更加灵活。array_merge

在PHP中,有许多强大的数组函数可以使数组的操作更加方便和快捷。当我们需要将两个数组拼成一个关联数组时,可以使用PHP的array_combine函数来实现这一操作。这个函数实际上是用来将一个数组的键作为另一个数组的值,合并成一个新的关联数组。接下来,我们将会讲解如何使用PHP中的array_combine函数将两个数组拼成关联数组。了解array_comb

Vue3.2setup语法糖是在单文件组件(SFC)中使用组合式API的编译时语法糖解决Vue3.0中setup需要繁琐将声明的变量、函数以及import引入的内容通过return向外暴露,才能在使用的问题1.在使用中无需return声明的变量、函数以及import引入的内容,即可在使用语法糖//import引入的内容import{getToday}from'./utils'//变量constmsg='Hello!'//函数func

JavaScript中return的用法,需要具体代码示例在JavaScript中,return语句用于指定从函数中返回的值。它不仅可以用于结束函数的执行,还可以将一个值返回给调用函数的地方。return语句有以下几个常见的用法:返回一个值return语句可以用来返回一个值给调用函数的地方。下面是一个简单的示例:functionadd(a,b){

JavaScript 函数提供两个接口实现与外界的交互,其中参数作为入口,接收外界信息;返回值作为出口,把运算结果反馈给外界。下面本篇文章带大家了解一下JavaScript函数返回值,浅析下return语句的用法,希望对大家有所帮助!
