import numpy as np
black, blue, red, green, yellow, grey, pink, orange, teal, maroon = range(10)
def main(input_grid: np.ndarray) -> np.ndarray:
	output_grid = np.copy(input_grid) # create a copy of the input grid
	# iterate over the entire grid
	for i in range(input_grid.shape[0]):
		for j in range(input_grid.shape[1]):
			if input_grid[i][j] == black: # if the current block is black
				if i == 0 or input_grid[0][j] != grey: # if the topmost block is not grey
					continue
				if j == input_grid.shape[1]-1 or input_grid[i][input_grid.shape[1]-1] != grey: # if the rightmost block is not grey
					continue
				output_grid[i][j] = red # paint the black block red if the topmost and rightmost blocks are grey
	return output_grid
