亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

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

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

leetcode怎么解決青蛙跳臺階問題

發布時間:2021-12-15 12:02:03 來源:億速云 閱讀:150 作者:iii 欄目:大數據

本篇內容介紹了“leetcode怎么解決青蛙跳臺階問題”的有關知識,在實際案例的操作過程中,不少人都會遇到這樣的困境,接下來就讓小編帶領大家學習一下如何處理這些情況吧!希望大家仔細閱讀,能夠學有所成!

一只青蛙一次可以跳上1級臺階,也可以跳上2級臺階。求該青蛙跳上一個 n 級的臺階總共有多少種跳法。

答案需要取模 1e9+7(1000000007),如計算初始結果為:1000000008,請返回 1。

示例 1:

輸入:n = 2

輸出:2

示例 2:

輸入:n = 7

輸出:21

提示:

0 <= n <= 100

解題思路

設跳上 nn 級臺階有 f(n)f(n) 種跳法。在所有跳法中,青蛙的最后一步只有兩種情況:跳上 11 級或 22 級臺階。

當為 11 級臺階:剩 n-1n?1 個臺階,此情況共有 f(n-1)f(n?1) 種跳法;

當為 22 級臺階:剩 n-2n?2 個臺階,此情況共有 f(n-2)f(n?2) 種跳法。

f(n)f(n) 為以上兩種情況之和,即 f(n)=f(n-1)+f(n-2)f(n)=f(n?1)+f(n?2) ,以上遞推性質為斐波那契數列。本題可轉化為 求斐波那契數列第 nn 項的值 ,與 面試題10- I. 斐波那契數列 等價,唯一的不同在于起始數字不同。

青蛙跳臺階問題:f(0)=1f(0)=1 , f(1)=1f(1)=1 , f(2)=2f(2)=2 ;

斐波那契數列問題:f(0)=0f(0)=0 , f(1)=1f(1)=1 , f(2)=1f(2)=1 。

斐波那契數列的定義是 f(n + 1) = f(n) + f(n - 1)f(n+1)=f(n)+f(n?1) ,生成第 nn 項的做法有以下幾種:

遞歸法:

原理:把 f(n)f(n) 問題的計算拆分成 f(n-1)f(n?1) 和 f(n-2)f(n?2) 兩個子問題的計算,并遞歸,以 f(0)f(0) 和 f(1)f(1) 為終止條件。

缺點:大量重復的遞歸計算,例如 f(n)f(n) 和 f(n - 1)f(n?1) 兩者向下遞歸都需要計算 f(n - 2)f(n?2) 的值。

記憶化遞歸法:

原理:在遞歸法的基礎上,新建一個長度為 nn 的數組,用于在遞歸時存儲 f(0)f(0) 至 f(n)f(n) 的數字值,重復遇到某數字時則直接從數組取用,避免了重復的遞歸計算。

缺點:記憶化存儲的數組需要使用 O(N)O(N) 的額外空間。

動態規劃:

原理:以斐波那契數列性質 f(n + 1) = f(n) + f(n - 1)f(n+1)=f(n)+f(n?1) 為轉移方程。

從計算效率、空間復雜度上看,動態規劃是本題的最佳解法。

動態規劃解析:

狀態定義:設 dpdp 為一維數組,其中 dp[i]dp[i] 的值代表 斐波那契數列第 $i$ 個數字 。

轉移方程:dp[i + 1] = dp[i] + dp[i - 1]dp[i+1]=dp[i]+dp[i?1] ,即對應數列定義 f(n + 1) = f(n) + f(n - 1)f(n+1)=f(n)+f(n?1) ;

初始狀態:dp[0] = 1dp[0]=1, dp[1] = 1dp[1]=1 ,即初始化前兩個數字;

返回值:dp[n]dp[n] ,即斐波那契數列的第 nn 個數字。

空間復雜度優化:

若新建長度為 nn 的 dpdp 列表,則空間復雜度為 O(N)O(N) 。

由于 dpdp 列表第 ii 項只與第 i-1i?1 和第 i-2i?2 項有關,因此只需要初始化三個整形變量 sum, a, b ,利用輔助變量 sumsum 使 a, ba,b 兩數字交替前進即可 (具體實現見代碼) 。

因為節省了 dpdp 列表空間,因此空間復雜度降至 O(1)O(1) 。

循環求余法:

大數越界:隨著 nn 增大, f(n)f(n) 會超過 Int32 甚至 Int64 的取值范圍,導致最終的返回值錯誤。

求余運算規則:設正整數 x, y, px,y,p ,求余符號為 \odot⊙ ,則有 (x + y) \odot p = (x \odot p + y \odot p) \odot p(x+y)⊙p=(x⊙p+y⊙p)⊙p 。

解析:根據以上規則,可推出 f(n) \odot p = [f(n-1) \odot p + f(n-2) \odot p] \odot pf(n)⊙p=[f(n?1)⊙p+f(n?2)⊙p]⊙p ,從而可以在循環過程中每次計算 sum = a + b \odot 1000000007sum=a+b⊙1000000007 ,此操作與最終返回前取余等價

代碼實現

func numWays(n int) int {   if n==0{       return 1   }   if n<=2{       return n   }
  a:=make([]int,n)   a[0]=1   a[1]=2   c:=1000000007   for i:=2;i<n;i++{       a[i]=(a[i-1]+a[i-2])%c   }   return a[n-1]}

“leetcode怎么解決青蛙跳臺階問題”的內容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業相關的知識可以關注億速云網站,小編將為大家輸出更多高質量的實用文章!

向AI問一下細節

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

AI

招远市| 庆城县| 黔西| 屏东市| 定结县| 泗水县| 根河市| 东源县| 大兴区| 威海市| 铜梁县| 泽州县| 寻乌县| 甘泉县| 崇礼县| 浦城县| 电白县| 德昌县| 雷山县| 彭州市| 府谷县| 从江县| 富源县| 南部县| 清原| 江川县| 廉江市| 三门峡市| 潢川县| 昌邑市| 信丰县| 灵丘县| 越西县| 淳安县| 文化| 揭西县| 武夷山市| 库车县| 海阳市| 乳源| 靖宇县|