Minimum Cost to Destination

You have been given an N*M matrix where there are 'N' rows and 'M' columns filled with '0s' and '1s'.


'1' means you can use the cell, and '0' means the cell is blocked. You can move in the 4 following directions from a particular position (i, j):

1. Left - (i, j-1)
2. Right - (i, j+1)
3. Up - (i-1, j)
4. Down - (i+1, j)

Now, for moving in the up and down directions, it costs you $1, and moving to the left and right directions are free of cost.

You have to calculate the minimum cost to reach (X, Y) from (0, 0) where 'X' is the row number and 'Y' is the column number of the destination cell. If it is impossible to reach the destination, print -1.

Input format :
The first line of input contains two integer values, 'N' and 'M', separated by a single space. They represent the 'rows' and 'columns' respectively, for the two-dimensional array/list.

The second line onwards, the next 'N' lines or rows represent the i-th row values.

Each of the ith row constitutes 'M' column values separated by a single space.

The next and the final line contains two single space separated Integers 'X' and 'Y' where 'X' is the row number and 'Y' is the column number of the destination cell.
Output format :
Print the minimum cost required to reach the destination (X, Y) from (0, 0).
If it is impossible to reach the destination, print -1.
Note :
1. You are not required to print the output explicitly, it has already been taken care of. Just implement the given function.

2. 'X' and 'Y' are 0-based indexing. 

3. matrix[0][0] will always be 1.
Constraints :
1 <= N <= 10^3
1 <= M <= 10^3
0 <= matrix[i][j] <= 1
0 <= X < N
0 <= Y < M

where 'N' represents the number of rows, 'M' represents the number of columns, 'matrix[i][j]' represents the elements of the matrix, and 'X' and 'Y' represents the coordinates of the destination point.
Time Limit: 1 sec.
CodingNinjas
author
2y

Simple DP Question.
Used a 2D memoization array.
I used top down approach, bottom up is also easily applicable for this.

CodingNinjas
author
2y
Backtracking

Maintain a visited array and try to explore all the possibilities with the help of backtracking.

  1. Start with (0, 0) and mark it as visited and try to move in all 4 directions.
  2. Say at any poin...read more
CodingNinjas
author
2y
BFS

We will use Breadth-First Search with Priority Queue to solve the problem (Similar to Dijkstra’s Algorithm).

To make our operations easy, we create a new class called Cell, which stores the cost to...read more

CodingNinjas
author
2y
0-1 BFS

We will use Breadth-First Search with deque to solve the problem (This technique is called 0-1 BFS and it is used when we can only have 0 or 1 as our cost from one node to another)

To make our ...read more

Add answer anonymously...
Oyo Rooms Software Developer Interview Questions
Stay ahead in your career. Get AmbitionBox app
qr-code
Helping over 1 Crore job seekers every month in choosing their right fit company
65 L+

Reviews

4 L+

Interviews

4 Cr+

Salaries

1 Cr+

Users/Month

Contribute to help millions
Get AmbitionBox app

Made with ❤️ in India. Trademarks belong to their respective owners. All rights reserved © 2024 Info Edge (India) Ltd.

Follow us
  • Youtube
  • Instagram
  • LinkedIn
  • Facebook
  • Twitter