70. Climbing Stairs - Detailed Explanation
Free Coding Questions Catalog
Boost your coding skills with our essential coding questions catalog. Take a step towards a better tech career now!
Problem Statement
Description:
You are climbing a staircase that has n steps. Each time you can either climb 1 or 2 steps. Your task is to determine in how many distinct ways you can climb to the top.
Key Details:
- You can take either 1 or 2 steps at a time.
- The order in which you take the steps matters.
- The problem asks for the total number of distinct ways to reach the top.
Example Inputs, Outputs, and Explanations
-
Example 1:
- Input:
n = 2
- Output:
2
- Explanation:
- There are two ways to climb 2 steps:
- 1 step + 1 step.
- A single 2-step jump.
- There are two ways to climb 2 steps:
- Input:
-
Example 2:
- Input:
n = 3
- Output:
3
- Explanation:
- There are three ways to climb 3 steps:
- 1 step + 1 step + 1 step.
- 1 step + 2 steps.
- 2 steps + 1 step.
- There are three ways to climb 3 steps:
- Input:
-
Example 3 (Edge Case):
- Input:
n = 1
- Output:
1
- Explanation:
- Only one step is available, so there is only one way to climb it.
- Input:
Constraints
- n is a positive integer (typically, 1 ≤ n ≤ 45).
- The solution should be efficient to handle the upper bound of n.
Hints to Approach the Solution
-
Think Recursively:
- To reach step n, you can come from either step n - 1 (by taking 1 step) or step n - 2 (by taking 2 steps). This observation naturally leads to a recurrence relation.
-
Dynamic Programming:
- Since the recurrence relation for climbing stairs has overlapping subproblems, you can use dynamic programming (either top-down with memoization or bottom-up) to efficiently solve the problem.
-
Fibonacci Connection:
- Notice that the number of ways to climb to step n follows a Fibonacci-like sequence. Specifically, if we denote
dp[i]
as the number of ways to reach step i, then: [ dp[i] = dp[i - 1] + dp[i - 2] ] - With base cases:
dp[0] = 1
(one way to stand at the bottom) anddp[1] = 1
(one way to climb the first step).
- Notice that the number of ways to climb to step n follows a Fibonacci-like sequence. Specifically, if we denote
Approach 1: Recursive with Memoization
Explanation
- Method:
- Define a recursive function that computes the number of ways to reach the nth step.
- Use memoization to cache the results of subproblems and avoid repeated calculations.
- Pros:
- Easy to understand and implement.
- Cons:
- Recursive calls might add overhead, and a bottom-up approach can be more space/time efficient.
Pseudocode
function climb(n):
if n <= 1: return 1
if memo[n] exists: return memo[n]
memo[n] = climb(n - 1) + climb(n - 2)
return memo[n]
Approach 2: Bottom-Up Dynamic Programming
Explanation
- Method:
- Create an array
dp
wheredp[i]
represents the number of ways to reach stepi
. - Fill in the array iteratively using the recurrence relation.
- Create an array
- Pros:
- Iterative solution, which is straightforward and efficient.
- Cons:
- Uses O(n) extra space. However, this can be optimized further.
Pseudocode
dp[0] = 1, dp[1] = 1
for i from 2 to n:
dp[i] = dp[i - 1] + dp[i - 2]
return dp[n]
Approach 3: Fibonacci Number Optimization (Constant Space)
Explanation
- Method:
- Realize that only the last two values are needed at any step.
- Maintain two variables and update them iteratively.
- Pros:
- Uses O(1) space and is very efficient.
- Cons:
- Slightly less intuitive if you are not familiar with Fibonacci sequences.
Pseudocode
a = 1, b = 1
for i from 2 to n:
temp = a + b
a = b
b = temp
return b
Code Implementations
Python Code
Python3
Python3
. . . .
Java Code
Java
Java
. . . .
Complexity Analysis
- Time Complexity:
- Both the bottom-up DP and the constant-space Fibonacci solution run in O(n) time, as they iterate from 2 to n.
- Space Complexity:
- Recursive with Memoization: O(n) space for the recursion stack and memo array.
- Bottom-Up DP: O(n) space for the dp array.
- Fibonacci Optimization: O(1) space, since only two variables are maintained.
Step-by-Step Walkthrough (Visual Example)
Consider n = 4:
-
Initialization:
- Set
a = 1
(ways to climb 0 steps) andb = 1
(ways to climb 1 step).
- Set
-
Iteration:
- For step 2:
temp = a + b = 1 + 1 = 2
- Update:
a = b (1)
,b = temp (2)
. - Now,
b = 2
(2 ways to reach step 2).
- For step 3:
temp = a + b = 1 + 2 = 3
- Update:
a = b (2)
,b = temp (3)
. - Now,
b = 3
(3 ways to reach step 3).
- For step 4:
temp = a + b = 2 + 3 = 5
- Update:
a = b (3)
,b = temp (5)
. - Now,
b = 5
(5 ways to reach step 4).
- For step 2:
-
Result:
- The final result is
5
.
- The final result is
Common Mistakes & Edge Cases
Common Mistakes
- Incorrect Base Cases:
- Not handling the case when n = 0 or n = 1 properly.
- Overcomplicating the Recursion:
- Not using memoization can lead to redundant calculations and exponential time complexity.
- Ignoring Optimization:
- Using a full DP array when only two variables are needed.
Edge Cases
- n = 0 or n = 1:
- These should return 1, as there is only one way to be at the start or to take one step.
- Large n (within given constraints):
- Ensure that the solution is efficient enough to handle the maximum value of n (e.g., n = 45).
Alternative Variations and Related Problems
Variations
- Climbing Stairs with More Options:
- What if you can take 1, 2, or 3 steps at a time? The recurrence relation changes accordingly.
- Minimum Cost Climbing Stairs:
- Instead of counting ways, each step may have a cost, and you need to minimize the total cost.
Related Problems for Further Practice
- House Robber
- Fibonacci Number
- Minimum Cost Climbing Stairs
TAGS
leetcode
CONTRIBUTOR
Design Gurus Team
-
GET YOUR FREE
Coding Questions Catalog
Boost your coding skills with our essential coding questions catalog.
Take a step towards a better tech career now!
Explore Answers
Related Courses
Grokking the Coding Interview: Patterns for Coding Questions
Grokking the Coding Interview Patterns in Java, Python, JS, C++, C#, and Go. The most comprehensive course with 476 Lessons.

Grokking Modern AI Fundamentals
Master the fundamentals of AI today to lead the tech revolution of tomorrow.
Grokking Data Structures & Algorithms for Coding Interviews
Unlock Coding Interview Success: Dive Deep into Data Structures and Algorithms.
One-Stop Portal For Tech Interviews.
Copyright © 2025 Design Gurus, LLC. All rights reserved.