Path with minimum effort

Graphs Shortest Path Algorithms Hard
  • Fun Fact: The concept underlying this problem is similar to the logic used in routing and navigation software, such as Google Maps or Waze
  • In these applications, the idea is to find the shortest or least effort route between two points
  • But instead of considering differences in heights, they use factors such as distance, traffic, and road conditions to decide what the 'effort' of a potential route would be
  • In fact, this programming problem essentially models what is known as 'cost-based pathfinding,' which is a common problem in computer science for designing intelligent routing systems in various domains, not just geospatial navigation!

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