
문제 링크
/**
* @param {number} n
* @return {number}
*/
var climbStairs = function(n) {
if (n === 0 || n === 1) { return 1 }
let dp = []
dp[1] = 1
dp[2] = 2
for (let i = 3; i <= n; i++) {
dp[i] = dp[i-1] + dp [i-2]
}
return dp[n]
};
개인적인 느낌은 dynamic programming(dp)의 대표적인 문제인거 같다.
해당 문제의 점화식은 dp[i] = dp[i-1] + dp[i-2] 이다.
1, 1, 2, 3, 5, 8 ···