Path with minimum effort

Graphs Shortest Path Algorithms Hard

A hiker is preparing for an upcoming hike. Given heights, a 2D array of size rows x columns, where heights[row][col] represents the height of the cell (row, col). The hiker is situated in the top-left cell, (0, 0), and hopes to travel to the bottom-right cell, (rows-1, columns-1) (i.e.,0-indexed). He can move up, down, left, or right. He wishes to find a route that requires the minimum effort.


A route's effort is the maximum absolute difference in heights between two consecutive cells of the route.

Examples:

Input: heights = [[1,2,2],[3,8,2],[5,3,5]]

Output: 2

Explanation: The route of [1,3,5,3,5] has a maximum absolute difference of 2 in consecutive cells. This is better than the route of [1,2,2,2,5], where the maximum absolute difference is 3.

Input: heights = [[1,2,3],[3,8,4],[5,3,5]]

Output: 1

Explanation: The route of [1,2,3,4,5] has a maximum absolute difference of 1 in consecutive cells, which is better than route [1,3,5,3,5].

Input: heights = [[1,2,1,1,1],[1,2,1,2,1],[1,2,1,2,1],[1,2,1,2,1],[1,1,1,2,1]]

Constraints

  • rows == heights.length
  • columns == heights[i].length
  • 1 <= rows, columns <= 100
  • 1 <= heights[i][j] <= 106

Hints

  • Use a min-heap (priority queue) where each entry contains (effort, row, col), prioritizing smaller efforts. Maintain a minEffort[][] matrix initialized to ∞, where minEffort[r][c] stores the smallest effort required to reach cell (r, c).
  • "Start at (0,0) with effort 0, and use Dijkstra’s relaxation technique to update neighboring cells, pushing valid lower-effort paths into the heap. Once (rows-1, columns-1) is reached, return the minimum possible effort required. "

Company Tags

Rakuten PwC PayPal Snowflake Zomato NVIDIA Salesforce Uber McKinsey & Company MongoDB Visa Airbnb OYO Rooms Red Hat Oracle IBM Bloomberg Etsy Unity Technologies Bungie Johnson & Johnson Pinterest Texas Instruments Robinhood Splunk Google Microsoft Amazon Meta Apple Netflix Adobe