遞迴和迭代

2021-06-16 09:37:50 字數 1200 閱讀 6114

遞迴和迭代是兩種常用的演算法,很多人知道怎麼寫遞迴和迭代,但是不知道什麼時候該用遞迴,什麼時候該用迭代。下面的**分別通過使用遞迴和迭代計算fibonacci數列,可以很清楚的看到效率的驚人差別。當然,很難有個準則說什麼時候該用遞迴,什麼時候該用迭代,但有乙個很簡單的判斷方法: 

如果你的遞迴呼叫是在函式的最後一行,那一般來說都可以改寫成迭代,且效率要高很多。  (執行測試**時,不要太大的基數,否則你會沒耐心等結果的...在我的機器上,輸入50,迭代幾乎是瞬間出結果,但遞迴用了125s...光fib_cur(3)就計算了4,807,526,976次...沒事的同學可以觀察一下這個遞迴占用了多少stack。

標籤:《無》

view source

print?

01#include

02#include

03

04longfib_iter(intn);

05longfib_cur(intn);

06

07staticlongcount = 0;

08

09intmain()

26

27longfib_cur(intn)

34

35longfib_iter(intn)

45returnresult;

46}

遞迴和迭代 迭代與遞迴

很多程式設計小白都會遇到 迭代 和 遞迴 的問題 包括我自己 大部分同學還是不知道迭代與遞迴的區別。下面我就嘗試用最通俗易懂的模式講解遞迴與迭代的區別。1.迭代 迭代其實很簡單,我們在程式設計中經常用到迭代。比如說 i 1 print i 這個就是乙個迭代,沒想到吧。迭代的意思其實就是在迴圈 現了參...

遞迴和迭代

分享自 酷勤網 www.kuqin.com 遞迴函式 遞迴可以描述不同的概念,如果說乙個函式是遞迴的,那麼就是說函式的定義中 直接或者間接地 引用了該函式本身。比如求斐波那契數列,使用swift實現 func fib n int intreturn fib n 1 fib n 2 從函式定義看,fi...

遞迴和迭代

遞迴和迭代都是迴圈中的一種。簡單地說,遞迴是重複呼叫函式自身實現迴圈。迭代是函式內某段 實現迴圈,而迭代與普通迴圈的區別是 迴圈 中參與運算的變數同時是儲存結果的變數,當前儲存的結果作為下一次迴圈計算的初始值。遞迴迴圈中,遇到滿足終止條件的情況時逐層返回來結束。迭代則使用計數器結束迴圈。當然很多情況...