Skip to content

Commit

Permalink
0070 Solved
Browse files Browse the repository at this point in the history
  • Loading branch information
anomot committed Apr 18, 2020
1 parent d297eb2 commit c713a7b
Show file tree
Hide file tree
Showing 3 changed files with 102 additions and 0 deletions.
Binary file not shown.
Binary file added 0070-Climbing-Stairs/Animation/Animation.gif
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
102 changes: 102 additions & 0 deletions 0070-Climbing-Stairs/Article/0070-Climbing-Stairs.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,102 @@
## **LeetCode 70 号问题爬楼梯**

> 本文首发于公众号图解面试算法」, [图解 LeetCode ](<https://github.com/MisterBooo/LeetCodeAnimation>) 系列文章之一.
>
> 同步博客https://www.algomooc.com

题目来源于 LeetCode 上第 70 号问题爬楼梯题目难度为 Easy

### 题目描述

假设你正在爬楼梯需要 `n` 阶你才能到达楼顶

每次你可以爬 `1` `2` 个台阶你有多少种不同的方法可以爬到楼顶呢

**注意给定 n 是一个正整数。**

### 示例1

> 输入2
>
> 解释有两种方法可以爬到楼顶
>
> 1. 1 + 1
>
> 2. 2

### 题目解析

试着倒推想一下,就能发现这个问题可以被分解为一些包含最优子结构的子问题,它的最优解可以从其子问题
的最优解来有效地构建,因此我们可以使用`动态规划`解决这个问题.

`i` 阶可以由以下两种方法得到

在第 `(i - 1)` 阶后向上爬 1

在第 `(i - 2)` 阶后向上爬 2

所以到达第 `i` 阶的方法总数就是到第 `(i - 1)` 阶和第 `(i - 2)` 阶的方法数之和

`dp[i]dp[i]` 表示能到达第 `i` 阶的方法总数,那么DP推导公式就是:

> $$
> dp[i] = dp[i1] + dp[i2]
> $$



### 动画理解

<img src="../Animation/Animation.gif" alt="Animation" style="zoom:150%;" />

### 参考代码

```javascript
/**
* JavaScript 描述
*/
var climbStairs = function(n) {
let temp = new Array(n+1);
temp[1] = 1;
temp[2] = 2;
for (let i = 3; i < temp.length; i++) {
temp[i] = temp[i-1] + temp[i-2];
}
return temp[n];
}
```

#### 复杂度分析

- 时间复杂度:`O(n)`,单循环到 n
- 空间复杂度:`O(n)`,dpdp 数组用了 n 的空间

### 进一步优化

根据推导公式不难发现,我们要求的结果就是数组的最后一项,而最后一项又是前面数值叠加起来的,那么我们只需要两个变量保存 `i - 1` `i - 2` 的值就可以了.

```javascript
/**
* JavaScript 描述
*/
var climbStairs = function(n) {
if (n == 1) {
return 1;
}
let first = 1,
second = 2;
for (let i = 3; i <= n; i++) {
let third = first + second;
first = second;
second = third;
}
return second;
}
```

#### 复杂度分析

- 时间复杂度O(n),单循环到 n
- 空间复杂度O(1),用到了常量的空间

![qrcode](../../Pictures/qrcode.jpg)

0 comments on commit c713a7b

Please sign in to comment.