假设你正在爬楼梯。需要 n
阶你才能到达楼顶。
每次你可以爬 1
或 2
个台阶。你有多少种不同的方法可以爬到楼顶呢?
示例 1:
输入:n = 2 输出:2
解释:有两种方法可以爬到楼顶。 1. 1 阶 + 1 阶 2. 2 阶
示例 2:输入:n = 3 输出:3
解释:有三种方法可以爬到楼顶。 1. 1 阶 + 1 阶 + 1 阶 2. 1 阶 + 2 阶 3. 2 阶 + 1 阶
提示:1 <= n <= 45
#include<iostream>
#include<unordered_map>
using namespace std;
//常规递归型
/*int fun(int n)
{
if (n == 1)
return 1;
if (n == 2)
return 2;
int sum = fun(n - 1) + fun(n - 2);
return sum;
}*/
//循环
/*int fun(int n)
{
int p = 0, q = 0, t = 1;
for (int i = 0; i < n; i++)
{
p = q;
q = t;
t = p + q;
}
return t;
}*/
//递归优化结果存储在哈希表中
/*int fun(int n)
{
unordered_map<int, int>mp;
if (n == 1)
return 1;
if (n == 2)
return 2;
auto it = mp.find(n);
if (it != mp.end())
return it->second;
int sum = fun(n - 1) + fun(n - 2);
mp.insert(pair<int, int>(n, sum));
return sum;
}*/
int main()
{
int n;
cin >> n ;
int sum = fun(n);
cout << sum;
}