This is the 8th day of my participation in the August More Text Challenge. For details, see:August is more challenging

Image rendering

The title

There is a picture represented as a two-dimensional array of integers, each of which represents the size of the picture’s pixel value, ranging from 0 to 65535.

You are given a coordinate (sr, sc) representing the pixel value (row, column) at the beginning of the image rendering and a newColor value, newColor, to let you recolor the image.

In order to complete the color work, starting from the initial coordinates, record the connected pixels whose pixel values are the same as the initial coordinates in the four directions of the initial coordinates, and then record the qualified pixels in the four directions and the connected pixels whose pixel values are the same as the initial coordinates in the corresponding four directions… Repeat the process. Change the color value of all recorded pixels to the new color value.

Finally, the rendered image is returned after coloring.

Example 1: input: image = [,1,1 [1], [1, 0], [1, 1]] sr = 1, sc = 1, newColor = 2 output: [,2,2 [2], [2 0], [2, 1]] resolution: In the middle of the image, (coordinate (sr,sc)=(1,1)), the color of all qualified pixels on the path is changed to 2. Notice that the lower right pixel is not changed to 2 because it is not the pixel that is connected to the original point in four directions: up, down, left, right.Copy the code

Answer key

The question was very long and I had to read it for a long time before I understood the requirements. Up, down, left, and right at the given position, and the values in all four directions must be the same as the values at the given point. In this way, when the given point is changed to a new value, the values in the four directions will also change. After that, take points in the four directions as fixed points, find the right, up, down and left of each, and change the same value into the new value. And so on.

Train of thought: the topic is clear, train of thought since also have. First of all, there must be a recursive process in four directions: up, down, left and right.

  • The new value is the same as the original value and returns the original array.
  • Different. It starts at this point and goes up, down, left and right. If you have the same value as the intermediate point in all four directions, you need to change it to the same value as the intermediate point.
    • Button border. In the recursion, if the four directions of the intermediate point are in the outermost circle, and then spread out, then the case of the superbound can be directly returned
    • There is no need to change the fixed point value when it is different from the current point value.

code

var floodFill = function (image, sr, sc, newColor) {
    let m = image.length, n = image[0].length, oldColor = image[sr][sc]
    if (oldColor == newColor) return image
    let fill = (i, j) = > {
        if (i < 0 || j < 0|| i >= m || j >= n || image[i][j] ! = oldColor)return
        image[i][j] = newColor
        fill(i + 1, j)
        fill(i - 1, j)
        fill(i, j + 1)
        fill(i, j - 1)
    }
    fill(sr, sc)
    return image
};
Copy the code

The largest area of the island

The title

Given a non-empty two-dimensional array grid containing 0s and 1s.

An island is a combination of contiguous 1’s (land), where “contiguous” requires that the 1’s are adjacent horizontally or vertically. You can assume that all four edges of the grid are surrounded by zeros (water).

Finds the largest island area in the given two-dimensional array. (If there are no islands, the return area is 0.)

 

Example 1: ,0,0,0,0,0,0,1,1,1,0,0,0,0,1,0,0,0,0,1,0,0,0,0,0 [[0], [0], [0,1,1,0,1,0,0,0,0,0,0,0,0], [0,1,0,0,1,1,0,0,1,0,1,0,0]. ,1,0,0,1,1,0,0,1,1,1,0,0 [0], [0,0,0,0,0,0,0,0,0,0,1,0,0], [0,0,0,0,0,0,0,1,1,1,0,0,0], [0,0,0,0,0,0,0,1,1,0,0,0,0]]Copy the code

We should return 6 for the given matrix up here. Note that the answer should not be 11, because islands can only contain 1’s in four directions, horizontal or vertical.

Answer key

This is a little bit similar to the last problem. So this is a given point, and it’s spreading out; And this is how many points are connected in all four directions. We can iterate through it, but in the recursion we need to get to zero, so we don’t have to iterate through it.

Traversal: When the point is 1, a recursive operation is performed to find the maximum area. The recursion spreads from the current point in four directions: up, down, left and right. Again, we need to pay attention to the boundary problem (recursive termination conditions). If the current recursion point is not zero except that the four directions do not cross the boundary.

code

var maxAreaOfIsland = function (grid) {
    let m = grid.length, n = grid[0].length, maxArea = 0
    const Island = (i, j) = > {
        if (i < 0 || j < 0 || i >= m || j >= n || grid[i][j] == 0) return 0
        grid[i][j] = 0
        let max = 1
        max += Island(i + 1, j)
        max += Island(i - 1, j)
        max += Island(i, j - 1)
        max += Island(i, j + 1)
        return max
    }
    for (let i = 0; i < m; i++) {
        for (let j = 0; j < n; j++) {
            if (grid[i][j] == 1) {
                maxArea = Math.max(maxArea, Island(i, j))
            }
        }
    }
    return maxArea
};
Copy the code

Topic source: Leetcode