Solution: Flood Fill

Let's solve the Flood Fill problem using the Backtracking pattern.

Statement#

We are given the following values as input to begin with:

  • The coordinates of a source cell, i.e., sr and sc.

  • A target value, target.

  • An (m×n)(m \times n) grid.

Our task is to perform flood fill by updating the values of the four directionally connected cells, which have the same value as the source cell with the target value.

How to perform flood fill:

Suppose that a (4×4)(4 \times 4) grid has a source value of 11 at coordinates [1,1][1, 1]. We perform flood fill on its neighboring cells only if they have the same source value as this cell. Once all adjacent cells are updated, return the new grid after performing flood fill.

If no neighboring cell has a value equal to the source cell, only update the source cell with the target value and return the updated grid.

Constraints:

  • 11 \leq grid.length, grid[i].length 30\leq 30

  • 00 \leq grid[i][j], target 216\leq 2^{16}

  • 00 \leq sr <\lt grid.length

  • 00 \leq sc <\lt grid[i].length

Solution#

The idea is to change the value of cells in a grid using the depth-first search (DFS) algorithm. The process begins by checking the value of the starting cell. If it already matches the desired target value, the grid is returned unaltered. However, if the value of the starting cell is different from the target value, then we need to update the value of all four directionally connected cells in the grid as well.

We will start by replacing the value of the starting cell with the target value and then use a DFS algorithm to visit the four adjacent cells with the same value as the starting cell. If they have the same value as the starting cell, their value is updated to the target value. This process is repeated until all connected cells of the starting cell have been visited and their values replaced.

The following illustration shows these steps in detail:

Created with Fabric.js 3.6.6

1 of 32

Created with Fabric.js 3.6.6

2 of 32

Created with Fabric.js 3.6.6

3 of 32

Created with Fabric.js 3.6.6

4 of 32

Created with Fabric.js 3.6.6

5 of 32

Created with Fabric.js 3.6.6

6 of 32

Created with Fabric.js 3.6.6

7 of 32

Created with Fabric.js 3.6.6

8 of 32

Created with Fabric.js 3.6.6

9 of 32

Created with Fabric.js 3.6.6

10 of 32

Created with Fabric.js 3.6.6

11 of 32

Created with Fabric.js 3.6.6

12 of 32

Created with Fabric.js 3.6.6

13 of 32

Created with Fabric.js 3.6.6

14 of 32

Created with Fabric.js 3.6.6

15 of 32

Created with Fabric.js 3.6.6

16 of 32

Created with Fabric.js 3.6.6

17 of 32

Created with Fabric.js 3.6.6

18 of 32

Created with Fabric.js 3.6.6

19 of 32

Created with Fabric.js 3.6.6

20 of 32

Created with Fabric.js 3.6.6

21 of 32

Created with Fabric.js 3.6.6

22 of 32

Created with Fabric.js 3.6.6

23 of 32

Created with Fabric.js 3.6.6

24 of 32

Created with Fabric.js 3.6.6

25 of 32

Created with Fabric.js 3.6.6

26 of 32

Created with Fabric.js 3.6.6

27 of 32

Created with Fabric.js 3.6.6

28 of 32

Created with Fabric.js 3.6.6

29 of 32

Created with Fabric.js 3.6.6

30 of 32

Created with Fabric.js 3.6.6

31 of 32

Created with Fabric.js 3.6.6

32 of 32

Let’s look at the code for this solution below:

Flood Fill

Time complexity#

The time complexity of this solution is O(m×n)O(m \times n), where mm is the number of rows, and nn is the number of columns in the grid.

Space complexity#

In the worst case, the recursion stack could grow to the total cell count, which is m×nm \times n. Therefore, the overall space complexity of this solution is O(m×n)O(m \times n).

Flood Fill

Subsets: Introduction