class Solution {
public int climbStairs(int n) {
// 处理特殊情况
if (n == 1) {
return 1;
}
if (n == 2) {
return 2;
}
// 定义并初始化dp数组
int[] dp = new int[n + 1];
dp[1] = 1;
dp[2] = 2;
// 执行动态推导
for (int i = 3; i <= n; i++) {
// 使用递推公式
dp[i] = dp[i - 1] + dp[i - 2];
}
return dp[n];
}
}