您好,登錄后才能下訂單哦!
這篇文章給大家分享的是有關(guān)js如何實(shí)現(xiàn)斐波那契的內(nèi)容。小編覺得挺實(shí)用的,因此分享給大家做個參考,一起跟隨小編過來看看吧。
斐波那契
最簡單的做法:遞歸。
function fibonacci(n){
if (n <= 0) {
return 0;
}
if (n == 0) {
return 1;
}
return fibonacci(n-1) + fibonacci(n-2);
}
但是遞歸會有嚴(yán)重的效率問題。比如想要求得f(10),首先需要求f(9)和f(8)。同樣,想求f(9),首先需要f(8)和f(7)…這樣就有很多重復(fù)值,計算量也很大。
我自己是一名從事了多年開發(fā)的web前端老程序員,目前辭職在做自己的web前端私人定制課程,今年年初我花了一個月整理了一份最適合2019年學(xué)習(xí)的web前端學(xué)習(xí)干貨,各種框架都有整理,送給每一位前端小伙伴,想要獲取的可以在后臺私信我:前端,即可免費(fèi)獲取。
改進(jìn):從下往上計算,首先根據(jù)f(0)和f(1)計算出f(2),再根據(jù)f(1)和f(2)計算出f(3)……以此類推就可以計算出第n項。時間復(fù)雜度O(n)。
function fibonacci(n){
let ori = [0,1];
if (n < 2) {
return ori[n];
};
let fiboOne = 1,fiboTwo = 0,fiboSum = 0;
for (let i = 2; i <= n; i++) {
fiboSum = fiboOne + fiboTwo;
fiboTwo = fiboOne;
fiboOne = fiboSum;
}
return fiboSum;
}
console.log(fibonacci(5));
感謝各位的閱讀!關(guān)于“js如何實(shí)現(xiàn)斐波那契”這篇文章就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,讓大家可以學(xué)到更多知識,如果覺得文章不錯,可以把它分享出去讓更多的人看到吧!
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報,并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。