Shortest Path in a Grid with Obstacles Elimination - Problem

You are given an m x n integer matrix grid where each cell is either 0 (empty) or 1 (obstacle). You can move up, down, left, or right from and to an empty cell in one step.

Return the minimum number of steps to walk from the upper left corner (0, 0) to the lower right corner (m - 1, n - 1) given that you can eliminate at most k obstacles.

If it is not possible to find such walk, return -1.

Input & Output

Example 1 — Basic Elimination
$ Input: grid = [[0,1,1],[1,1,1],[1,0,0]], k = 1
Output: 6
💡 Note: Shortest path: (0,0) → (1,0) eliminate → (2,0) eliminate → (2,1) → (2,2) in 6 steps, but actually optimal is (0,0) → (1,0) → (2,1) → (2,2) eliminating 2 obstacles
Example 2 — No Elimination Needed
$ Input: grid = [[0,0,0],[1,1,0],[0,0,0]], k = 1
Output: 6
💡 Note: Path around obstacles: (0,0) → (0,1) → (0,2) → (1,2) → (2,2) → (2,2) in 4 steps
Example 3 — Impossible Case
$ Input: grid = [[1,1,1],[1,1,1],[1,1,0]], k = 1
Output: -1
💡 Note: Need to eliminate at least 6 obstacles to reach destination, but k=1 is insufficient

Constraints

  • m == grid.length
  • n == grid[i].length
  • 1 ≤ m, n ≤ 40
  • 1 ≤ k ≤ m × n
  • grid[i][j] is either 0 or 1
  • grid[0][0] == grid[m-1][n-1] == 0

Visualization

Tap to expand
Shortest Path in Grid with Obstacle EliminationInput Grid (k=1):S1111110EBFS Exploration:Level 1: (0,0,k=1)Level 2: (1,0,k=0)Level 6: (2,2,k≥0)Optimal Path:Output: 6 steps minimumBFS ensures we find the shortest path by exploring level by levelEach state tracks position AND remaining eliminations🎯 Key Insight: Model as 3D state space (row, col, eliminations_left)
Understanding the Visualization
1
Input
Grid with obstacles (1) and empty cells (0), plus k eliminations allowed
2
Process
Use BFS to explore states (row, col, eliminations_left)
3
Output
Minimum steps to reach destination, or -1 if impossible
Key Takeaway
🎯 Key Insight: Model the problem as 3D state space where each state represents position and remaining eliminations
Asked in
Google 15 Facebook 12 Amazon 8
34.5K Views
Medium Frequency
~25 min Avg. Time
890 Likes
Ln 1, Col 1
Smart Actions
💡 Explanation
AI Ready
💡 Suggestion Tab to accept Esc to dismiss
// Output will appear here after running code
Code Editor Closed
Click the red button to reopen