Search⌘ K
AI Features

Solution: Unique Paths III

Explore how to apply backtracking to solve the Unique Paths III problem by identifying all valid four-directional paths in a grid. Understand the recursive exploration of paths that visit every empty cell exactly once, marking visited cells, and backtracking when hitting dead ends to count all possible solutions efficiently.

Statement

You are given a  m×nm \times n  integer array, grid, where each cell, grid[i][j], can have one of the following values:

  • 1 indicates the starting point. There is exactly one such square.

  • 2 marks the ending point. There is exactly one such square.

  • 0 represents empty squares that can be walked over.

  • -1 represents obstacles that cannot be crossed.

Your task is to return the total number of unique four-directional paths from the starting square (1) to the ending square (2), such that every empty square is visited exactly once during the walk.

Constraints:

  • mm ==== grid.length

  • nn ==== grid[i].length

  • 11 \leq ...