久久久久久久av_日韩在线中文_看一级毛片视频_日本精品二区_成人深夜福利视频_武道仙尊动漫在线观看

PHP中遞歸的實現實例詳解

遞歸(http:/en.wikipedia.org/wiki/Recursive)是一種函數調用自身(直接或間接)的一種機制,這種強大的思想可以把某些復雜的概念變得極為簡單。這篇文章主要介紹了PHP中遞歸的實現實例詳

遞歸的定義

    遞歸(http:/en.wikipedia.org/wiki/Recursive)是一種函數調用自身(直接或間接)的一種機制,這種強大的思想可以把某些復雜的概念變得極為簡單。在計算機科學之外,尤其是在數學中,遞歸的概念屢見不鮮。例如:最常用于遞歸講解的斐波那契數列便是一個極為典型的例子,而其他的例如階層(n!)也可以轉化為遞歸的定義(n! = n*(n-1)!).即使是在現實生活中,遞歸的思想也是隨處可見:例如,由于學業問題你需要校長蓋章,然而校長卻說“只有教導主任蓋章了我才會蓋章”,當你找到教導主任,教導主任又說:“只有系主任蓋章了我才會蓋章”...直到你最終找到班主任,在得到班主任豪爽的蓋章之后,你要依次返回到系主任、教導主任、最后得到校長的蓋章,過程如下:

PHP中遞歸的實現實例詳解

遞歸函數是一種調用自己的函數。寫遞歸函數時要小心,因為可能會無窮遞歸下去。必須確保有充分的方法來終止遞歸。

一:使用 參數引用 完成遞歸函數。操作的是同一塊內存地址。

<?php
$i=1; 
function test(&$i) 
{
echo $i; 
$i++; 
 if ($i < 10) 
{ 
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 < 10 ) { 
     test ();
  } 
  $i --;// 在每一層遞歸結束時自減,這一句可以幫助理解遞歸函數的執行過程 
}
test();// 輸出123456789
test();// 輸出123456789 
?>

例1. 使用全局變量的情況 遞歸遍歷文件夾下的所有文件

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:使用靜態變量的情況遞歸遍歷文件夾下的所有文件

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);

總結

以上所述是小編給大家介紹的PHP中遞歸的實現實例詳解,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對網站的支持!

【網站聲明】本站除付費源碼經過測試外,其他素材未做測試,不保證完整性,網站上部分源碼僅限學習交流,請勿用于商業用途。如損害你的權益請聯系客服QQ:2655101040 給予處理,謝謝支持。

相關文檔推薦

這篇文章主要介紹了PHP定義字符串的四種方式,非常不錯,具有參考借鑒價值,需要的朋友可以參考下
下面小編就為大家分享一篇php 替換文章中的圖片路徑,下載圖片到本地服務器的方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
下面小編就為大家分享一篇PHP給源代碼加密的幾種方法匯總(推薦),具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
下面小編就為大家分享一篇php打開本地exe程序,js打開本地exe應用程序,并傳遞相關參數方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
這篇文章主要介紹了PHP類的反射來實現依賴注入過程以及相關知識點分享,對此有興趣的朋友跟著小編學習下吧。
php遍歷一個文件夾內的所有文件和文件夾,并刪除所有文件夾和子文件夾下的所有文件的代碼,通過遞歸方式實現達到清空一個目錄的效果。本文給大家分享實例代碼,需要的朋友參考
主站蜘蛛池模板: 亚洲综合大片69999 | www.中文字幕| 亚洲精品一区中文字幕乱码 | 97人人澡人人爽91综合色 | 神马久久春色视频 | 91不卡在线 | 欧美二级 | 日韩av最新网址 | 日韩中文字幕一区二区 | 久久三区 | 久久国产精彩视频 | 国产精品免费一区二区三区四区 | 91精品国模一区二区三区 | 99re热精品视频 | 亚洲一区二区三区在线播放 | 激情五月婷婷 | 色婷综合网 | 国产高清免费视频 | 天天躁天天操 | 中文字幕亚洲免费 | 成人精品国产一区二区4080 | 在线观看国产h | 81精品国产乱码久久久久久 | 7799精品视频天天看 | 成人欧美一区二区三区在线播放 | 女同久久 | 亚洲精品二区 | 国产超碰人人爽人人做人人爱 | 欧美一区二区三区在线视频 | 91精品国产综合久久久动漫日韩 | 人人叉| 黄色网址免费在线观看 | 亚洲成人免费视频在线观看 | 性一爱一乱一交一视频 | 欧美男人天堂 | 国产成人jvid在线播放 | 91亚洲精华国产 | 日日夜夜操天天干 | 日韩欧美三区 | 黑人巨大精品欧美黑白配亚洲 | 欧美h版|