LeetCode简单题之图像渲染
题目
有一幅以二维整数数组表示的图画,每一个整数表示该图画的像素值大小,数值在 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
LeetCode简单题之图像渲染相关推荐
- LeetCode(733)——图像渲染(JavaScript)
有一幅以二维整数数组表示的图画,每一个整数表示该图画的像素值大小,数值在 0 到 65535 之间. 给你一个坐标 (sr, sc) 表示图像渲染开始的像素值(行 ,列)和一个新的颜色值 newCol ...
- [Leetcode][第733题][JAVA][图像渲染][BFS][DFS]
[问题描述][简单] [解答思路] 千万不要想复杂了 不是三维空间 是一维空间 ! 本题要求将给定的二维数组中指定的「色块」染成另一种颜色.「色块」的定义是:直接或间接相邻的同色方格构成的整体. 可以 ...
- LeetCode简单题之图片平滑器
题目 包含整数的二维矩阵 M 表示一个图片的灰度.你需要设计一个平滑器来让每一个单元的灰度成为平均灰度 (向下舍入) ,平均灰度的计算是周围的8个单元和它本身的值求平均,如果周围的单元格不足八个,则尽 ...
- LeetCode简单题之基于排列构建数组
题目 给你一个 从 0 开始的排列 nums(下标也从 0 开始).请你构建一个 同样长度 的数组 ans ,其中,对于每个 i(0 <= i < nums.length),都满足 ans ...
- LeetCode简单题之Excel 表中某个范围内的单元格
题目 Excel 表中的一个单元格 (r, c) 会以字符串 "" 的形式进行表示,其中: 即单元格的列号 c .用英文字母表中的 字母 标识. 例如,第 1 列用 'A' 表示, ...
- LeetCode简单题之增量元素之间的最大差值
题目 给你一个下标从 0 开始的整数数组 nums ,该数组的大小为 n ,请你计算 nums[j] - nums[i] 能求得的 最大差值 ,其中 0 <= i < j < n 且 ...
- LeetCode简单题之二进制矩阵中的特殊位置
题目 给你一个大小为 rows x cols 的矩阵 mat,其中 mat[i][j] 是 0 或 1,请返回 矩阵 mat 中特殊位置的数目 . 特殊位置 定义:如果 mat[i][j] == 1 ...
- LeetCode简单题之设计 Goal 解析器
题目 请你设计一个可以解释字符串 command 的 Goal 解析器 .command 由 "G"."()" 和/或 "(al)" 按某种 ...
- LeetCode简单题之检查两个字符串数组是否相等
题目 给你两个字符串数组 word1 和 word2 .如果两个数组表示的字符串相同,返回 true :否则,返回 false . 数组表示的字符串 是由数组中的所有元素 按顺序 连接形成的字符串. ...
最新文章
- 使用JCIFS获取远程共享文件
- 王道考研——计算机组成原理(第二章 数据的表示和运算)
- 一步一步学Silverlight 2系列(22):在Silverlight中如何用JavaScript调用.NET代码
- 关于sizeof的一些东西
- 解决Error: VM Exception while processing transaction: revert
- 查找html的第三个input元素,获取HTML元素的3个方法
- shell的简单应用
- nature:2021年最值得关注的技术
- 家电电子行业内卷严重,你还觉得单片机没用吗
- WIN7激活工具拒绝访问cannot open file C:\OEMSF解决方法
- matplotlib实现区域颜色填充
- 扫描的PDF转Word工具实践(主要ORC识别图片功能转换)
- java swing小程序:手动绘制美国队长盾牌
- jQuery之浏览器打印插件
- 使用单视点模型进行水下标定的分析
- 第二次作业助教博客 —— 撰写第三周课程总结及实验报告(一)
- canvas绘图夕颜技术笔记
- 第四周【项目2-长方形周长和面积】
- mt7620参考设计原理图,mt7620芯片资料,mt7620处理器资料
- git只合并merge部分代码的方法
热门文章
- 2022-2028年中国煤化工行业市场前景分析预测报告
- 2022-2028年中国演出市场深度调研与投资可行性报告
- 判断两个树是否相等和判断tree1是否包含tree2 python实现
- Mybatis传递多个参数的4种方式
- 在idea中移除子模块Moudle后重新导入
- CodeGen结构循环回路
- 人工智能在音频链中找到自己的声音
- 【网站汇总】安装教程系列
- ‘utf-8‘ codec can‘t decode byte 0xa8 in position 1210: invalid start byte报错解决
- Android 计时器 Chronometer