【BFS 解决 FloodFill 算法】1. 图像渲染(medium)

BFS 解决 FloodFill 算法

1. 图像渲染(medium)

题⽬链接:733. 图像渲染

题⽬描述:

有⼀幅以 m x n 的⼆维整数数组表⽰的图画 image ,其中 imageij 表⽰该图画的像素值⼤⼩。

你也被给予三个整数 sr , sc 和 newColor 。你应该从像素 imagesrsc 开始对图像进⾏ 上⾊填充。

为了完成 上⾊⼯作 ,从初始像素开始,记录初始坐标的 上下左右四个⽅向上 像素值与初始坐标相同的相连像素点,接着再记录这四个⽅向上符合条件的像素点与他们对应 四个⽅向上 像素值与初始坐标相同的相连像素点,......,重复该过程。将所有有记录的像素点的颜⾊值改为newColor 。

最后返回 经过上⾊渲染后的图像 。

⽰例 1:

输⼊: image = \[1,1,1,1,1,0,1,0,1],sr = 1, sc = 1, newColor = 2

输出: \[2,2,2,2,2,0,2,0,1]

解析: 在图像的正中间,(坐标(sr,sc)=(1,1)),在路径上所有符合条件的像素点的颜⾊都被更改成2。

注意,右下⻆的像素没有更改为 2,因为它不是在上下左右四个⽅向上与初始点相连的像素点。

⽰例 2:

输⼊: image = \[0,0,0,0,0,0], sr = 0, sc = 0, newColor = 2

输出: \[2,2,2,2,2,2]

算法思路:

可以利⽤「深搜」或者「宽搜」,遍历到与该点相连的所有「像素相同的点」,然后将其修改成指定的像素即可。

算法代码:

java 复制代码
class Solution
{
 int[] dx = {0, 0, 1, -1};
 int[] dy = {1, -1, 0, 0};
 public int[][] floodFill(int[][] image, int sr, int sc, int color) 
 {
	 int prev = image[sr][sc]; // 统计刚开始的颜⾊
	 if(prev == color) return image; // 处理边界情况
	 int m = image.length, n = image[0].length;
	 Queue<int[]> q = new LinkedList<>();
	 q.add(new int[]{sr, sc});
	 while(!q.isEmpty())
	 {
		 int[] t = q.poll();
		 int a = t[0], b = t[1];
		 image[a][b] = color;
		 // 上下左右四个⽅向
		 for(int i = 0; i < 4; i++)
		 {
		 	int x = a + dx[i], y = b + dy[i];
			 if(x >= 0 && x < m && y >= 0 && y < n && image[x][y] == prev)
			 {
			 	q.add(new int[]{x, y});
			 }
		 }
	 }
	 return image;
 }
}
相关推荐
QiLinkOS7 小时前
第三视觉理解徐玉生与他的商业活动(30)
大数据·c++·人工智能·算法·开源协议
疯狂打码的少年7 小时前
【操作系统】页面置换算法(OPT/FIFO/LRU)
算法
小O的算法实验室7 小时前
2026年CIE,优化客货协同运输:综合地铁系统的列车容量动态分配
算法
Coder_Shenshen8 小时前
西门子S7CommPlus协议鉴权算法原理与流程详解
网络·后端·算法
硕风和炜9 小时前
【LeetCode: 2492. 两个城市间路径的最小分数 + DFS】
java·算法·leetcode·深度优先·dfs·bfs·并查集
我是一颗柠檬10 小时前
【Java项目技术亮点】加权轮询负载均衡算法
java·算法·负载均衡
灯厂码农10 小时前
C语言动态内存分配完全指南(malloc、calloc、realloc、free)
java·c语言·算法
凯瑟琳.奥古斯特11 小时前
K次取反最大化数组和解法(力扣1005)
开发语言·c++·算法·leetcode·职场和发展
Jerry12 小时前
LeetCode 203. 移除链表元素
算法
地平线开发者12 小时前
征程 6 | 工具链 QAT ObserverBase 源码解析
算法