カエルは一度に1つまたは2つのステップまでジャンプできます。カエルがnレベルのステップでジャンプするジャンプ方法の総数を見つけます。
答えは1e9 + 7(1000000007)を法とする必要があります。計算の初期結果が1000000008の場合は、1を返します。
例1:
输入:n = 2
输出:2
例2:
输入:n = 7
输出:21
例3:
输入:n = 0
输出:1
促す:
0 <= n <= 100
注:この質問は、メインサイトの70の質問と同じです:https://leetcode-cn.com/problems/climbing-stairs/
動的計画法
f(x)= f(x-1)+ f(x-2)
アイデアリファレンス:https://blog.csdn.net/qq_30457077/article/details/114276198
class Solution {
public:
int numWays(int n) {
int p = 0, q = 0, r = 1;//初始化p为0 q为f(0)==0 r为f(1)==1
//p q r分别指f(x - 2) f(x - 1) f(x)
for (int i = 1; i <= n; ++i) {
p = q;
q = r;
r = (p + q) % 1000000007;
}
return r;
}
};