小編給大家分享一下js實現(xiàn)遞歸函數(shù)的方法,希望大家閱讀完這篇文章后大所收獲,下面讓我們一起去探討吧!
創(chuàng)新互聯(lián)是一家專業(yè)提供江蘇企業(yè)網(wǎng)站建設(shè),專注與網(wǎng)站制作、做網(wǎng)站、H5建站、小程序制作等業(yè)務(wù)。10年已為江蘇眾多企業(yè)、政府機構(gòu)等服務(wù)。創(chuàng)新互聯(lián)專業(yè)網(wǎng)站制作公司優(yōu)惠進(jìn)行中。js中的遞歸函數(shù)就是指的是在代碼中調(diào)用自身的函數(shù),它具有三個特征分別是當(dāng)輸入錯誤時發(fā)生終止的終止條件,基本案例它是遞歸函數(shù)的目標(biāo),遞歸即函數(shù)實現(xiàn)的功能
遞歸函數(shù)指的一個函數(shù)調(diào)用自身函數(shù),接下來在文章中為大家分享的是在js中如何實現(xiàn)遞歸函數(shù),具有一定的參考價值,希望對大家有所幫助。
我們可以使用JavaScript從函數(shù)的外部或者是在其他函數(shù)中調(diào)用函數(shù)。甚至是可以從內(nèi)部調(diào)用函數(shù)。當(dāng)一個函數(shù)調(diào)用自身時,就稱為遞歸函數(shù),例
<script> function demo(x) { if (x < 0) return; if (x === 0) return 1; return x * demo(x - 1); } console.log(demo(3)); </script>
輸出結(jié)果為:6
從上面的例子可以看出在return x * demo(x?-?1)
中實際上是再次調(diào)用自身函數(shù)(demo(x-1))
,但是其參數(shù)比第一次調(diào)用的參數(shù)少一個,這就是遞歸函數(shù)
遞歸函數(shù)的三大特征
終止條件
終止條件就類似于緊急制動器,它在輸入錯誤的情況可以防止遞歸,在上文的案例中“if (x < 0) return”
就是設(shè)置的終止條件,所以說當(dāng)輸入負(fù)數(shù)時就不會運行遞歸函數(shù)。
基本案例
基本案例就是遞歸函數(shù)的目標(biāo)。基本案例通常是放在一個if語句中,在上文的案例中“if (x === 0) return 1;"
就是一個基本案例,因為當(dāng)x的值減少到0時就能成功的確認(rèn)階乘值了
遞歸
遞歸就是實現(xiàn)的功能,在上例中“return x * demo(x?—?1);”
就是遞歸函數(shù)實際發(fā)生的位置,將函數(shù)返回的值x乘以demo(x-1)
的值就是我們最后所要求的值
例:
<script> function revStr(str){ //終止條件 //str === ''是基本案例 if (str === '') return ''; //遞歸 return revStr(str.substr(1)) + str[0]; } console.log(revStr('cat')); </script>
輸出結(jié)果為:tac
看完了這篇文章,相信你對js實現(xiàn)遞歸函數(shù)的方法有了一定的了解,想了解更多相關(guān)知識,歡迎關(guān)注創(chuàng)新互聯(lián)網(wǎng)站制作公司行業(yè)資訊頻道,感謝各位的閱讀!
網(wǎng)站題目:js實現(xiàn)遞歸函數(shù)的方法-創(chuàng)新互聯(lián)
瀏覽地址:http://aaarwkj.com/article0/ccjsio.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供微信公眾號、做網(wǎng)站、響應(yīng)式網(wǎng)站、ChatGPT、用戶體驗、手機網(wǎng)站建設(shè)
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)
猜你還喜歡下面的內(nèi)容