php遞歸函數(shù)三種實(shí)現(xiàn)方法及如何實(shí)現(xiàn)數(shù)字累加
遞歸函數(shù)在編程中是比較常用的一類函數(shù),其特點(diǎn)是函數(shù)自身可以調(diào)用自身,但是必須在調(diào)用自身前有條件判斷,否則會(huì)導(dǎo)致無(wú)限調(diào)用下去。本文列出了三種遞歸函數(shù)實(shí)現(xiàn)方法,第一種利用引用做參數(shù),第二種利用全局變量,第三種利用靜態(tài)變量,理解此類問(wèn)題需要有點(diǎn)基礎(chǔ),包括對(duì)全局變量,引用,靜態(tài)變量的理解,也需對(duì)他們的作用范圍有所理解。在這不廢話了,具體介紹請(qǐng)看下文。
第一種方法:利用引用做參數(shù)
先不管引用做不做參數(shù),必須先明白引用到底是什么?引用不過(guò)是指兩個(gè)不同名的變量指向同一塊存儲(chǔ)地址。本來(lái)每個(gè)變量有各自的存儲(chǔ)地址,賦值刪除各行其道。
現(xiàn)在可好,兩個(gè)變量共享一塊存儲(chǔ)地址。 $a=&$b; 。實(shí)際上指的是 $a 不管不顧自己原來(lái)的存儲(chǔ)地址,非要和 $b 共享一室了。因而任何對(duì)存儲(chǔ)地址數(shù)值的改變都會(huì)影響兩個(gè)值?! ?/p>
函數(shù)之間本來(lái)也是各行其是,即便是同名函數(shù)。遞歸函數(shù)是考慮將引用作為參數(shù),成為一個(gè)橋梁,形成兩個(gè)函數(shù)間的數(shù)據(jù)共享。雖然兩個(gè)函數(shù)見(jiàn)貌似操作的是不同地址,但是實(shí)際上操作的是一塊兒內(nèi)存地址。
function test($a=0,&$result=array()){
$a++;
if ($a<10) {
$result[]=$a;
test($a,$result);
}
echo $a;
return $result;
}
上面的例子非常簡(jiǎn)答,以a<10作為判斷條件,條件成立,則把a(bǔ)賦給result[];將result的引用傳入函數(shù),會(huì)將每一次遞歸產(chǎn)生的a添加到結(jié)果數(shù)組result。因而本例生成的$result數(shù)組是 Array ( [0] => 1 [1] => 2 [2] => 3 [3] => 4 [4] => 5 [5] => 6 [6] => 7 [7] => 8 [8] => 9 ) 。
本例比較有意思的是echo a 的值。相信很多人認(rèn)為是12345678910吧,其實(shí)不然,是1098765432。為什么呢?因?yàn)楹瘮?shù)還沒(méi)執(zhí)行echo a前就進(jìn)行了下一次的函數(shù)遞歸。
真正執(zhí)行echo a是當(dāng)a<10條件不滿足的時(shí)候,echo a,返回result,對(duì)于上一層而言,執(zhí)行完遞歸函數(shù),開(kāi)始執(zhí)行本層的echo $a,依次類推。
第二種方法:利用全局變量
利用全局變量完成遞歸函數(shù),請(qǐng)確保你確實(shí)理解什么是全局變量。global在函數(shù)內(nèi)申明變量不過(guò)是外部變量的同名引用。變量的作用范圍仍然在本函數(shù)范圍內(nèi)。改變這些變量的值,外部同名變量的值自然也改變了。但一旦用了&,同名變量不再是同名引用。利用全局變量實(shí)現(xiàn)遞歸函數(shù)沒(méi)必要理解到這么深的一層,還保持原有對(duì)全局變量的看法就可以順理成章理解遞歸函數(shù)。
function test($a=0,$result=array()){
global $result;
$a++;
if ($a<10) {
$result[]=$a;
test($a,$result);
}
return $result;
}
第三種方法:利用靜態(tài)變量
我們常常在類中見(jiàn)到static,今天我們把它利用到遞歸函數(shù)中。請(qǐng)記住static的作用:僅在第一次調(diào)用函數(shù)的時(shí)候?qū)ψ兞窟M(jìn)行初始化,并且保留變量值。
舉個(gè)栗子:
function test(){
static $count=0;
echo $count;
$count++;
}
test();
test();
test();
test();
test();
請(qǐng)問(wèn)這一段代碼的執(zhí)行結(jié)果是多少?是00000么?必然不是。是01234。首先第一次調(diào)用test(),static對(duì) $count 進(jìn)行初始化,其后每一次執(zhí)行完都會(huì)保留 $count 的值,不再進(jìn)行初始化,相當(dāng)于直接忽略了 static $count=0; 這一句。
因而將static應(yīng)用到遞歸函數(shù)作用可想而知。在將需要作為遞歸函數(shù)間作為“橋梁"的變量利用static進(jìn)行初始化,每一次遞歸都會(huì)保留"橋梁變量"的值。
function test($a=0){
static $result=array();
$a++;
if ($a<10) {
$result[]=$a;
test($a);
}
return $result;
}
總結(jié)
所謂遞歸函數(shù),重點(diǎn)是如何處理函數(shù)調(diào)用自身是如何保證所需要的結(jié)果得以在函數(shù)間合理"傳遞",當(dāng)然也有不需要函數(shù)之間傳值得遞歸函數(shù),例如:
function test($a=0){
$a++;
if ($a<10) {
echo $a;
test($a);
}
}
下面通過(guò)一段代碼演示一下php使用遞歸函數(shù)實(shí)現(xiàn)數(shù)字累加的方法。
代碼如下所示:
<?php
function summation ($count) {
if ($count != 0) :
return $count + summation($count-1);
endif;
}
$sum = summation(10);
print "Summation = $sum";
?>
面對(duì)php遞歸函數(shù),不必要傷腦筋,深入的理解變量引用相關(guān)知識(shí)對(duì)解決此類問(wèn)題很有幫助,以上內(nèi)容就是php遞歸函數(shù)三種實(shí)現(xiàn)方法及如何實(shí)現(xiàn)數(shù)字累加的全部?jī)?nèi)容,希望對(duì)大家今后的學(xué)習(xí)有所幫助。
- PHP遞歸的三種常用方式
- PHP 無(wú)限分類三種方式 非函數(shù)的遞歸調(diào)用!
- php菜單/評(píng)論數(shù)據(jù)遞歸分級(jí)算法的實(shí)現(xiàn)方法
- PHP遞歸算法的簡(jiǎn)單實(shí)例
- PHP基于遞歸算法解決兔子生兔子問(wèn)題
- PHP基于非遞歸算法實(shí)現(xiàn)先序、中序及后序遍歷二叉樹(shù)操作示例
- PHP基于二分法實(shí)現(xiàn)數(shù)組查找功能示例【循環(huán)與遞歸算法】
- PHP實(shí)現(xiàn)字符串翻轉(zhuǎn)功能的方法【遞歸與循環(huán)算法】
- PHP基于遞歸實(shí)現(xiàn)的約瑟夫環(huán)算法示例
- PHP使用遞歸算法無(wú)限遍歷數(shù)組示例
- php獲得文件夾下所有文件的遞歸算法的簡(jiǎn)單實(shí)例
- PHP二分查找算法示例【遞歸與非遞歸方法】
- PHP冒泡算法詳解(遞歸實(shí)現(xiàn))
- 關(guān)于PHP遞歸算法和應(yīng)用方法介紹
- PHP遞歸算法的詳細(xì)示例分析
- php全排列遞歸算法代碼
- php實(shí)現(xiàn)遞歸的三種基本方式
相關(guān)文章
PHP編譯configure時(shí)常見(jiàn)錯(cuò)誤的總結(jié)
這篇文章主要介紹了PHP編譯configure時(shí)常見(jiàn)錯(cuò)誤的總結(jié)的相關(guān)資料,本文總結(jié)了一些常見(jiàn)的configure錯(cuò)誤信息和解決這些錯(cuò)誤的經(jīng)驗(yàn),需要的朋友可以參考下2017-08-08
php提取身份證號(hào)碼中的生日日期以及驗(yàn)證是否為成年人的函數(shù)
本篇文章使用php技術(shù)提取身份證號(hào)碼中的生日日期來(lái)判斷是否是未成年人的一個(gè)函數(shù)。下面小編把代碼分享給大家,供大家參考2015-09-09
Laravel 中創(chuàng)建 Zip 壓縮文件并提供下載的實(shí)現(xiàn)方法
這篇文章主要介紹了Laravel 中創(chuàng)建 Zip 壓縮文件并提供下載,本文通過(guò)兩個(gè)任務(wù),實(shí)例代碼相結(jié)合的形式給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2019-04-04
Yii實(shí)現(xiàn)MySQL多數(shù)據(jù)庫(kù)和讀寫分離實(shí)例分析
這篇文章主要介紹了Yii實(shí)現(xiàn)MySQL多數(shù)據(jù)庫(kù)和讀寫分離的方法,以實(shí)例形式詳細(xì)的分析了Yii數(shù)據(jù)庫(kù)讀寫分離的方法,是開(kāi)發(fā)大型項(xiàng)目非常實(shí)用的技巧,需要的朋友可以參考下2014-12-12
PHP開(kāi)發(fā)框架kohana3 自定義路由設(shè)置示例
這篇文章主要介紹了PHP開(kāi)發(fā)框架kohana3 自定義路由設(shè)置示例,kohana是一個(gè)純PHP5的開(kāi)發(fā)框架,需要的朋友可以參考下2014-07-07
Laravel使用模型實(shí)現(xiàn)like模糊查詢的例子
今天小編就為大家分享一篇Laravel使用模型實(shí)現(xiàn)like模糊查詢的例子,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2019-10-10
CI框架教程之優(yōu)化驗(yàn)證碼機(jī)制詳解【驗(yàn)證碼輔助函數(shù)】
這篇文章主要介紹了CI框架教程之優(yōu)化驗(yàn)證碼機(jī)制,結(jié)合實(shí)例形式詳細(xì)分析了CodeIgniter框架驗(yàn)證碼輔助函數(shù)相關(guān)使用及優(yōu)化操作技巧,需要的朋友可以參考下2019-04-04
thinkPHP自動(dòng)驗(yàn)證機(jī)制詳解
這篇文章主要介紹了thinkPHP自動(dòng)驗(yàn)證機(jī)制,結(jié)合實(shí)例形式分析了thinkPHP自動(dòng)驗(yàn)證機(jī)制的格式、原理與具體操作技巧,需要的朋友可以參考下2016-12-12
php求正負(fù)數(shù)數(shù)組中連續(xù)元素最大值示例
問(wèn)題是給出數(shù)組,該數(shù)組由正負(fù)數(shù)字組成,找出該數(shù)組中連續(xù)元素組成的子數(shù)組的最大值。下面是PHP實(shí)現(xiàn)的示例,需要的朋友可以參考下2014-04-04

