As Far from Land as Possible - Problem

Given an n x n grid containing only values 0 and 1, where 0 represents water and 1 represents land, find a water cell such that its distance to the nearest land cell is maximized, and return the distance.

If no land or water exists in the grid, return -1.

The distance used in this problem is the Manhattan distance: the distance between two cells (x0, y0) and (x1, y1) is |x0 - x1| + |y0 - y1|.

Input & Output

Example 1 — Basic Grid
$ Input: grid = [[1,0,1],[0,0,0],[1,0,1]]
Output: 2
💡 Note: The center cell (1,1) is farthest from land. Distance to nearest land at (0,1) is |1-0|+|1-1| = 1+0 = 1, to (1,0) is |1-1|+|1-0| = 0+1 = 1, so minimum is 1. But cell (1,1) has distance 2 to corners, making it the farthest point.
Example 2 — No Water
$ Input: grid = [[1,0,0],[0,1,0],[0,0,1]]
Output: 2
💡 Note: Water cells like (0,1) and (0,2) are distance 1 from land, but (0,2) is distance 2 from nearest land at (1,1): |0-1|+|2-1| = 1+1 = 2.
Example 3 — All Land
$ Input: grid = [[1,1],[1,1]]
Output: -1
💡 Note: No water cells exist, so return -1 as specified in the problem.

Constraints

  • n == grid.length
  • n == grid[i].length
  • 1 ≤ n ≤ 100
  • grid[i][j] is 0 or 1

Visualization

Tap to expand
As Far from Land as PossibleFind water cell with maximum Manhattan distance to nearest landInput Grid101000101Green=Land, Blue=WaterDistance Calculation111121111Numbers = distancesMaximumDistance: 2Center cell (1,1) is farthest from any land cellManhattan distance = |x₁-x₂| + |y₁-y₂|Use BFS from all land cells simultaneously for optimal O(n²) solution
Understanding the Visualization
1
Input Grid
3×3 grid with land (1) and water (0) cells
2
Calculate Distances
Find distance from each water cell to nearest land
3
Maximum Distance
Return the largest distance found
Key Takeaway
🎯 Key Insight: Use multi-source BFS starting from all land cells to efficiently find maximum distance to water
Asked in
Google 15 Amazon 12 Microsoft 8 Facebook 6
28.4K Views
Medium Frequency
~25 min Avg. Time
892 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