(DP) Climbing Stairs
28 Oct 2019 | algorithm programming leetcode정답을 단순화해서 쪼갤 수 없는지 생각해보면,
계단을 2번 또는 1번 오를 수 있으니, n이 3이상이라면, 모든 케이스에 계단을 2번 오르고 나머지 계단을 오르는것과, 계단을 1번 오르고 나머지 계단을 오르는 경우가 존재한다.
따라서 이를 점화식으로 세워보면, An = An-1 + An-2 이므로, 피보나치 수열의 값을 구하면 된다.
class Solution {
public int climbStairs(int n) {
if(n == 1) {
return 1;
}
else if(n == 2) {
return 2;
}
int[] dp = new int[n];
dp[0] = 1;
dp[1] = 2;
for(int i=2; i<n; i++) {
dp[i] = dp[i-1] + dp[i-2];
}
return dp[n-1];
}
}