Solution: Unique Paths
Let's solve the Unique Paths problem using the Dynamic Programming pattern.
Statement#
Imagine a scenario where an adventurous little robot, named Robi, has a mission to traverse a grid with m rows and n columns and reach a treasure box placed at 
Given the two integers, m and n, return the total number of unique paths that Robi can take from the grid's top-left corner to reach the bottom-right corner of the grid.
Constraints:
- 1 - m,- n- 100 
Solution#
So far, you’ve probably brainstormed some approaches on how to solve this problem. Let’s explore some of these approaches and figure out which one to follow while considering time complexity and any implementation constraints.
Naive approach#
The naive approach uses recursion to consider every possible path that the robot can take from the top-left corner of the grid to the bottom-right corner. The algorithm begins with the top-left corner and explores two branches: moving right and moving down. This process continues recursively, generating further branches for each valid move. Eventually, the recursion reaches the base cases:
- If the robot reaches the bottom-right corner, a single path is counted. 
- If it goes out of bounds or reaches an edge, such a path is not counted. 
The algorithm sums up the number of paths obtained through these recursive explorations and returns this number as the total number of unique paths.
Since this approach recalculates the overlapping subproblems, it becomes inefficient as the grid size grows, resulting in exponential time complexity. The robot takes a total of 
Optimized approach using dynamic programming #
Let’s look at the bottom-up dynamic programming approach to solve this problem. In this approach, solutions to smaller subproblems are stored in a table as they are computed, and these solutions are then used to solve larger subproblems until the main problem is solved.
For this specific problem, we start with solving the simplest cases along the first row and first column. These are straightforward because there's only one way to reach them. We save these solutions and then use them to find solutions for other cells by adding up the values from the cell above and the cell to the left. This process continues until we calculate the total unique paths to the bottom-right cell. The value in the bottom-right cell will represent the total number of unique paths. This approach avoids unnecessary calculations and is more efficient.
We start by creating a 2D array, grid, to store the results of smaller subproblems and then combine these results to get the final answer. We initialize grid with all 
            grid[row][col] = grid[row-1][col] + grid[row][col-1]
This is because the robot can only move either down or right. Therefore, the total number of ways to reach the current cell is the sum of the ways to reach the cell above it and the ways to reach the cell to its left. This process continues until all cells in the grid have been updated with the correct values. Finally, the function returns the value in the bottom-right cell of the grid, which represents the total number of unique paths to reach the bottom-right corner of the grid.
Now, let’s look at the following illustration to get a better understanding of the solution:
1 of 9
2 of 9
3 of 9
4 of 9
5 of 9
6 of 9
7 of 9
8 of 9
9 of 9
Let’s look at the code for this solution below:
Solution summary#
To recap, the solution to this problem can be divided into the following parts:
- A grid is created with all cells initialized to - to cater the base case. 
- Traverse the grid and update the value in the current cell by adding the value from the cell above and the value from the cell to the left. Keep doing this until we reach the bottom-right cell of the grid. 
- Return the value present in the bottom-right cell of the grid. 
Time complexity#
The time complexity of this solution is 
Space complexity#
The space complexity of this solution is proportional to the size of the grid, that is, 
Alternative solutions#
Now, let’s see some other ways to solve this problem.
The space-optimized solution#
If you have noticed from the optimized approach given above, in order to calculate the value of any particular cell, except for the cells in the first row and the first column, we only need the values from its previous row and column. This implies that we can get to our answer without storing the whole grid. Instead, we can use a rolling array and modify it until we get to our final answer.
We iterate over the entire rolling array and update its values for m number of times. For this, we'll use a nested loop. The outer loop will make us iterate the rolling array for m times and the inner loop will allow us to update the value of each element of the rolling array based on the values in the previous iteration. In each inner loop, the value of the first element of the rolling array won't be changed since it comes under the base case. To calculate the values for the rest of the elements, we use the sum of the current element and the previous element in the rolling array. These values represent values from the cell directly above the current cell and the cell to its left, respectively. The following illustration will help to get a better understanding of this solution:
1 of 14
2 of 14
3 of 14
4 of 14
5 of 14
6 of 14
7 of 14
8 of 14
9 of 14
10 of 14
11 of 14
12 of 14
13 of 14
14 of 14
Let's look at the code for this solution:
While the time complexity remains the same as the optimized approach above, i.e., 
Mathematical solution#
Another way to this problem is by using a mathematical approach—specifically, combinations and permutations. If we have a 
The binomial coefficient, denoted as 
In the context of this problem, 
Let's have a look at the code:
The loop in the function iterates from 1 to n - 1 (inclusive), which means it takes 
Unique Paths
Word Break