溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

怎么在JavaScript中實現尾遞歸

發布時間:2021-05-20 16:52:09 來源:億速云 閱讀:157 作者:Leah 欄目:web開發

這篇文章給大家介紹怎么在JavaScript中實現尾遞歸,內容非常詳細,感興趣的小伙伴們可以參考借鑒,希望對大家能有所幫助。

function tco(f) {
  var value;
  var active = false;
  var accumulated = [];
  return function accumulator() {
    accumulated.push(arguments);
    if(!active) {
      active = true;
      while(accumulated.length) {
        value = f.apply(this, accumulated.shift());
      }
      active = false;
      return value;
    }
  };
}
var sum = tco(function(x, y) {
  if(y > 0) {
    return sum(x + 1, y - 1);
  } else {
    return x;
  }
});
let res = sum(1, 5)
console.info(res);

這段代碼非常精妙!

分析

已知,任何遞歸可以寫成循環+棧。

實現將任何尾遞歸轉換成循環+棧執行而不需要針對每個尾遞歸函數寫一個實現版本的思路。

困難在于,任何尾遞歸,通用實現。而不是針對某一個遞歸函數。

要點:

棧中保存的數據,正是遞歸函數的參數。

通用實現,那就必須依賴原來的遞歸函數,循環的終止條件,正是遞歸的結束條件。

要將遞歸函數的參數入棧,而不修改原來的遞歸函數,就必須用一個函數代替遞歸函數被調用,從而取得函數入參。

遞歸函數的終止條件,每一個遞歸函數都不一樣,但是如果遞歸函數沒有被再次調用,說明已達到終止條件。即終止條件和遞歸函數的調用有關聯。而遞歸函數每次調用,都會將參數入棧。所以可以根據棧中是否有元素,推斷是否達到終止條件。

JavaScript的特點

1.JavaScript主要用來向HTML頁面添加交互行為。 2.JavaScript可以直接嵌入到HTML頁面,但寫成單獨的js文件有利于結構和行為的分離。 3.JavaScript具有跨平臺特性,在絕大多數瀏覽器的支持下,可以在多種平臺下運行。

關于怎么在JavaScript中實現尾遞歸就分享到這里了,希望以上內容可以對大家有一定的幫助,可以學到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

亚洲午夜精品一区二区_中文无码日韩欧免_久久香蕉精品视频_欧美主播一区二区三区美女