成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

遞歸

alphahans / 1125人閱讀

摘要:遞歸概念遞歸是一種針對簡單循環(huán)難以編程實現(xiàn)的問題,通過函數(shù)調(diào)用自身,提供優(yōu)雅解決方案的技術(shù)。擁有基礎(chǔ)情況或終止條件來停止遞歸。這個稱之為遞歸調(diào)用。為了避免重新創(chuàng)建字符串,使用遞歸輔助方法來進(jìn)行改良。

遞歸概念

遞歸是一種針對簡單循環(huán)難以編程實現(xiàn)的問題,通過函數(shù)調(diào)用自身,提供優(yōu)雅解決方案的技術(shù)。

遞歸都具有以下三個要點:

使用 if-else 或 switch 語句來引導(dǎo)不同的情況。

擁有基礎(chǔ)情況(base case)或終止條件(stopping condition)來停止遞歸。

每次遞歸調(diào)用都會簡化原始問題,讓它不斷接近基礎(chǔ)情況,所以可以用不同的參數(shù)調(diào)用自身方法,直到它變?yōu)檫@種基礎(chǔ)情況。這個稱之為遞歸調(diào)用(recursive call)。

示例,計算階乘

if(n == 0){ // base case
  return 0;
}else { // recursive call
  return n * factorial(n-1)
}
遞歸的優(yōu)勢--斐波那契數(shù)列

計算階乘很容易使用循環(huán)改寫,某些情況下,用循環(huán)不容易解決的問題可以利用遞歸給出一個直觀簡單的解法。

斐波那契數(shù)列從 0 到 1 開始,之后的每個數(shù)都是序列中的前兩個數(shù)之和,通過遞歸可以簡單的實現(xiàn)出來。

var count = 0;

function fib(n) {
    count++;
    if(n == 0){
        return 0;
    }else if(n == 1){
        return 1;
    }else {
        return fib(n-1) + fib(n-2);
    }
}

const result = fib(10);

console.log("result",result);
console.log("count",count);
// result 55
// count 177

程序中會出現(xiàn)很多重復(fù)調(diào)用,求第 10 個斐波那契數(shù),就調(diào)用了 177 次自身函數(shù),如果嘗試求出更大的斐波那契數(shù),那么相應(yīng)的調(diào)用次數(shù)就會急劇的增加。

優(yōu)化遞歸調(diào)用

將計算過的斐波那契值存起來,可以優(yōu)化遞歸調(diào)用。通過改良,求第 10 個斐波那契數(shù),只調(diào)用的 11 次自身函數(shù)。而且調(diào)用自身函數(shù)的次數(shù)永遠(yuǎn)是,n + 1 次,n 代表第 n 個需求的斐波那契數(shù)。

var count = 0;
const calculated = [];

function fib(n) {
    count++;

    if(n == 0){
        return 0;
    }else if(n == 1){
        return 1;
    }else {
        if(!calculated[n-1]){
            calculated[n-1] = fib(n-1);
        }

        if(!calculated[n-2]){
            calculated[n-2] = fib(n-2);
        }
        return calculated[n-1] + calculated[n-2];
    }

}

const result = fib(10);

console.log("result",result);
console.log("count",count);
// result 55
// count 11
遞歸輔助方法

有時候可以通過找到一個要解決的初始問題的類似問題,來找到初始問題的解決方案。這個類似的方法稱之為遞歸輔助方法。

舉例,如果一個字符串從左讀和從右讀都是一樣的,那么他就是一個回文串(palindrome)??梢酝ㄟ^下面的函數(shù)判斷。

function palindrome(str) {
    if(str.length <= 1 ){
        return true;
    }else if(str[0] !== str[str.length - 1]){
        return false;
    }else {
        return palindrome(str.slice(1,-1));
    }
}

const result = palindrome("ffffdffffd");

console.log(result); // ture

每次調(diào)用 palindrome 方法時,都會使用 str.slice 來創(chuàng)建一個新的字符串。
為了避免重新創(chuàng)建字符串,使用遞歸輔助方法 isPalindrome 來進(jìn)行改良。

function isPalindrome(str) {
    return palindrome(str,0,str.length-1);
}

function palindrome(str,low,high) {

    if(low >= high){
        return true;
    }else if(str[low] !== str[high]){
        return false;
    }else {
        low ++;
        high --;
        return palindrome(str,low,high);
    }
}

const result = isPalindrome("ffffdaaaerffffd");

console.log(result); // false

文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/80873.html

相關(guān)文章

  • js算法入門(3)--遞歸

    摘要:在遞歸過程中,未完成計算的函數(shù)將會掛起壓入調(diào)用堆棧,不然遞歸結(jié)束的時候沒辦法進(jìn)行回溯。這就引出了回溯法回溯法就是在達(dá)到遞歸邊界前的某層,由于一些事實導(dǎo)致已經(jīng)不需要前往任何一個子問題遞歸,就可以直接返回上一層。 1簡介 遞歸在前端開發(fā)中應(yīng)用還是非常廣泛的,首先DOM就是樹狀結(jié)構(gòu),而這種結(jié)構(gòu)使用遞歸去遍歷是非常合適的。然后就是對象和數(shù)組的深復(fù)制很多庫也是使用遞歸實現(xiàn)的例如jquery中的e...

    jzman 評論0 收藏0
  • 數(shù)據(jù)結(jié)構(gòu)與算法之精講「遞歸系列」

    摘要:終止條件遞推公式遞歸的分類通過做大量的題,根據(jù)遞歸解決不同的問題,引申出來的幾種解決和思考的方式。我們通過層與層之間的計算關(guān)系用遞推公式表達(dá)出來做計算,經(jīng)過層層的遞歸,最終得到結(jié)果值。 showImg(https://segmentfault.com/img/remote/1460000019222330); 前言 幾個月之前就想寫這樣一篇文章分享給大家,由于自己有心而力不足,沒有把真...

    zhichangterry 評論0 收藏0
  • 【C語言】玩轉(zhuǎn)遞歸——學(xué)好遞歸,你需要掌握的知識!

    摘要:所以,遞歸在編程中同樣是很重要的一個知識點。舉個例子用遞歸實現(xiàn)求第個斐波那契數(shù)??偨Y(jié)起來四個字大事化小繼續(xù)舉斐波那契數(shù)的例子三遞歸是怎樣運行的我們通過一道題目來講解。 ...

    Donne 評論0 收藏0
  • 對于遞歸的傲慢與偏見

    摘要:對于函數(shù)調(diào)用開銷,可以利用尾遞歸來解決,不過目前的引擎并沒有實現(xiàn)對尾遞歸的優(yōu)化,所以最開始我以為遞歸沒有理由比非遞歸更快。遞歸與堆棧非遞歸的算法使用一個堆棧來實現(xiàn)。 最近刷leetcode 79題 Word Search需要用到DFS算法,由于是刷leetcode,心想不能用遞歸,影響效率,于是利用stack完成。之后又利用遞歸(使用cache)實現(xiàn)了一次,結(jié)果竟然是遞歸的算法比非遞歸...

    Labradors 評論0 收藏0
  • 遞歸,就是這么簡單

    摘要:簡而言之,遞歸就是自己調(diào)用自己,但是這個調(diào)用它是有一定條件的,比如子問題須與原始問題為同樣的事,且更為簡單。當(dāng)時,這層遞歸返回,也就是返回到的這層遞歸。這時,至此,遞歸結(jié)束,返回結(jié)果給調(diào)用方。 showImg(https://segmentfault.com/img/bVbvZRe?w=1242&h=735); 什么是遞歸? 維基百科給出了如下定義: 程序調(diào)用自身的編程技巧稱為遞歸.遞...

    woshicixide 評論0 收藏0
  • 遞歸函數(shù)的執(zhí)行

    摘要:遞歸一個函數(shù)可以指向并調(diào)用自身。這是的一個獨特的用法,在這個結(jié)構(gòu)下無法替代,出錯但我們可以用下面這種方式,把遞歸函數(shù)賦值給一個變量 遞歸(Recursion) 一個函數(shù)可以指向并調(diào)用自身(call itself)。有三種方法可以達(dá)到這個目的: 函數(shù)名 arguments.callee 作用域下的一個指向該函數(shù)的變量名 上述概念引用自MDN,對遞歸概念不清楚的可以自行查看; 遞歸函數(shù)...

    tomato 評論0 收藏0

發(fā)表評論

0條評論

最新活動
閱讀需要支付1元查看
<