LeetCode简单题之图像渲染

news/2024/12/30 3:00:06/

题目

有一幅以二维整数数组表示的图画,每一个整数表示该图画的像素值大小,数值在 0 到 65535 之间。
给你一个坐标 (sr, sc) 表示图像渲染开始的像素值(行 ,列)和一个新的颜色值 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,
因为它不是在上下左右四个方向上与初始点相连的像素点。
注意:
image 和 image[0] 的长度在范围 [1, 50] 内。
给出的初始点将满足 0 <= sr < image.length 和 0 <= sc < image[0].length。
image[i][j] 和 newColor 表示的颜色值在范围 [0, 65535]内。
来源:力扣(LeetCode)

解题思路

  一般这类题可以使用广度优先搜索和深度优先搜索,得益于颜色的更改,我们无需特意建立visit数组以确定哪些元素是否被访问。

#广度优先搜索
class Solution:def floodFill(self, image: List[List[int]], sr: int, sc: int, newColor: int) -> List[List[int]]:if image[sr][sc]==newColor:return imageQ=[]   #队列Q.append((sr,sc))temp=image[sr][sc]while Q!=[]:t=Q[0]del Q[0]image[t[0]][t[1]]=newColorif t[0]-1>-1 and image[t[0]-1][t[1]]==temp:Q.append((t[0]-1,t[1]))if t[1]-1>-1 and image[t[0]][t[1]-1]==temp:Q.append((t[0],t[1]-1))if t[0]+1<len(image) and image[t[0]+1][t[1]]==temp:Q.append((t[0]+1,t[1]))if t[1]+1<len(image[0]) and image[t[0]][t[1]+1]==temp:Q.append((t[0],t[1]+1))return image

在这里插入图片描述

#深度优先搜索
class Solution:def floodFill(self, image: List[List[int]], sr: int, sc: int, newColor: int) -> List[List[int]]:if image[sr][sc]==newColor:return imagetemp=image[sr][sc]def dfs(x,y):if image[x][y]==temp:image[x][y]=newColorif x-1>-1 and image[x-1][y]==temp:dfs(x-1,y)if y-1>-1 and image[x][y-1]==temp:dfs(x,y-1)if x+1<len(image) and image[x+1][y]==temp:dfs(x+1,y)if y+1<len(image[0]) and image[x][y+1]==temp:dfs(x,y+1)dfs(sr,sc)return image

在这里插入图片描述


http://www.ppmy.cn/news/606196.html

相关文章

深度学习——Xavier初始化方法

20210609 https://blog.csdn.net/u011534057/article/details/51673458 https://blog.csdn.net/luoxuexiong/article/details/95772045 “Xavier”初始化方法是一种很有效的神经网络初始化方法&#xff0c;方法来源于2010年的一篇论文《Understanding the difficulty of traini…

Linux学习(8)——常用指令

✨Linux常用指令⛱️ 运行级别&#x1f308;&#x1f308;基本介绍&#x1f308;&#x1f308;如何指定运行级别⛱️(面试题)如何找回root密码⛱️帮助指令⛱️文件目录类⛱️博客推荐&#x1f4c3;个人主页:不断前进的皮卡丘&#x1f31e;博客描述: 梦想也许遥不可及&#xff…

LeetCode简单题之石头与宝石

题目 给你一个字符串 jewels 代表石头中宝石的类型&#xff0c;另有一个字符串 stones 代表你拥有的石头。 stones 中每个字符代表了一种你拥有的石头的类型&#xff0c;你想知道你拥有的石头中有多少是宝石。 字母区分大小写&#xff0c;因此 “a” 和 “A” 是不同类型的石头…

期望、方差、协方差及相关系数的基本运算

这篇文章总结了概率统计中期望、方差、协方差和相关系数的定义、性质和基本运算规则。 一、期望 定义&#xff1a; 设P(x)是一个离散概率分布函数自变量的取值范围是。那么其期望被定义为&#xff1a;设P(x)是一个连续概率分布函数 &#xff0c;那么他的期望是&#xff1a;性质…

[算法刷题笔记]二叉树练习(2):对称二叉树有关的练习

✨对称二叉树有关的练习前言⛱️对称二叉树&#x1f96a;&#x1f96a; 递归&#x1f96a;&#x1f96a;迭代(使用队列)⛱️相同的二叉树&#x1f96a;&#x1f96a;递归&#x1f96a;&#x1f96a;迭代法(使用队列)⛱️判断t1树中是否有与t2树完全相同的子树&#x1f96a;&…

LeetCode简单题之最大连续1的个数

题目 给定一个二进制数组&#xff0c; 计算其中最大连续 1 的个数。 示例&#xff1a; 输入&#xff1a;[1,1,0,1,1,1] 输出&#xff1a;3 解释&#xff1a;开头的两位和最后的三位都是连续 1 &#xff0c;所以最大连续 1 的个数是 3. 提示&#xff1a; 输入的数组只包含 0 和…

Spring Boot项目的搭建和运行

✨Spring Boot项目的搭建和运行&#x1f351;Spring Boot概述&#x1f34a;&#x1f34a;传统框架技术存在的问题&#x1f34a;&#x1f34a;主要特点&#x1f34a;&#x1f34a;环境要求&#x1f351;聚合工程/父子模块&#x1f351;第一个Spring Boot项目&#x1f351;目录结…

LeetCode简单题之密钥格式化

题目 有一个密钥字符串 S &#xff0c;只包含字母&#xff0c;数字以及 ‘-’&#xff08;破折号&#xff09;。其中&#xff0c; N 个 ‘-’ 将字符串分成了 N1 组。 给你一个数字 K&#xff0c;请你重新格式化字符串&#xff0c;使每个分组恰好包含 K 个字符。特别地&#x…