W3Cschool
恭喜您成為首批注冊用戶
獲得88經(jīng)驗值獎勵
上章中我提到一個函數(shù)調(diào)用另一個函數(shù)是符合語法的,而且我們已經(jīng)見過好幾個例子。但我還沒有告訴你們,一個函數(shù)調(diào)用它自己也是合法的。這是件好事,理由可能不那么顯而易見,但事實證明它是一個程序能做的最具魔力也最有趣的事情之一。
例如,下面這個函數(shù):
void countdown( int n) {
if (n == 0) {
cout << "Blastoff! << endl;
} else {
cout << n << endl;
countdown (n-1);
}
}
函數(shù)名是countdown,它把單個整數(shù)作為參數(shù),如果參數(shù)是0,則輸出單詞“Blastoff”。否則輸出這個參數(shù),然后調(diào)用countdown函數(shù)--也即它自身--傳入n-1作為輸入?yún)?shù)。
如果我們這么調(diào)用這函數(shù),會發(fā)生什么呢?
void main ()
{
countdown (3);
}
countdown從n=3開始執(zhí)行,由于n不為0,所以它輸出值3,然后調(diào)用它自己...
countdown從n=2開始執(zhí)行,由于n不為0,所以它輸出值2,然后調(diào)用它自己...
countdown從n=1開始執(zhí)行,由于n不為0,所以它輸出值2,然后調(diào)用它自己...
countdown從n=0開始執(zhí)行,由于n為0,所以它輸出單詞“Blastoff!”,然后返回。
countdown得到返回值n=1。
countdown得到返回值n=2。
countdown得到返回值n=3。
然后你會回到main函數(shù)(多美妙的一次旅行!)。因此輸出看起來會是這樣:
3
2
1
“Blastoff!”
作為第二個例子,讓我們再來看看函數(shù)newLine和threeLine。
void newLine() [
cout << endl;
}
void threeLine() {
newLine(); new Line(); new Line();
}
盡管它們奏效,但如果我希望再輸出2個或者106個換行符,它們并不能幫我們太多。一種更好的替代方法是這樣:
void nLines(int n){
if (n > 0) {
cout << endl;
nLines (n-1);
}
}
這段程序和countdown很相似,只要n大于0,它就會輸出一個換行符,然后調(diào)用它自身來輸出另外的n-1行。因此,總的換行符個數(shù)是1+(n-1), 最后得到n
一個函數(shù)調(diào)用它自身的過程被稱為遞歸,這些函數(shù)被稱為遞歸的。
Copyright©2021 w3cschool編程獅|閩ICP備15016281號-3|閩公網(wǎng)安備35020302033924號
違法和不良信息舉報電話:173-0602-2364|舉報郵箱:jubao@eeedong.com
掃描二維碼
下載編程獅App
編程獅公眾號
聯(lián)系方式:
更多建議: