当前位置: 首页 > news >正文

【广度优先搜索】图像渲染 岛屿数量

文章目录

  • 733. 图像渲染
  • 解题思路:BFS
  • 200. 岛屿数量
  • 解题思路:广度优先遍历

在这里插入图片描述

733. 图像渲染

733. 图像渲染

​ 有一幅以 m x n 的二维整数数组表示的图画 image ,其中 image[i][j] 表示该图画的像素值大小。

​ 你也被给予三个整数 sr , scnewColor 。你应该从像素 image[sr][sc] 开始对图像进行 上色填充

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

​ 最后返回 经过上色渲染后的图像

示例 1:

img
输入: 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]]

提示:

  • m == image.length
  • n == image[i].length
  • 1 <= m, n <= 50
  • 0 <= image[i][j], newColor < 216
  • 0 <= sr < m
  • 0 <= sc < n

解题思路:BFS

​ 这道题我们在学搜索算法的时候就接触到了,当时说可以使用 dfs 以及 bfs 方法来解决,现在我们就用 bfs 方法来解决它,并且这里对于 floodfill 算法以及这道题的思路就不再解释了,具体可以参考递归专题的笔记,但我相信这道题并不难理解!

​ 其实 bfs 非常简单,就是利用 队列 来实现这个过程!首先将起点位置放到队列中,然后进行循环,直到队列为空则停下来,而在循环过程中,将队头元素取出然后进行修改颜色,然后将对头元素邻近元素也就是上下左右四个元素,根据题目要求将符合的元素加入队列中,达到 bfs 效果!

​ 剩下的就没什么好说的了,具体参考下面代码:

class Solution {
private:int dx[4] = { 0, 0, 1, -1 };int dy[4] = { -1, 1, 0, 0 };
public:vector<vector<int>> floodFill(vector<vector<int>>& image, int sr, int sc, int newcolor) {// 1. 因为我们没使用used数组,所以需要先处理一下边界问题,防止死循环int oldcolor = image[sr][sc];if(oldcolor == newcolor)return image;// 2. 将起点放到队列中queue<pair<int, int>> bfs;bfs.push({sr, sc});while(!bfs.empty()){// 3. 将队头元素取出然后进行修改颜色auto [x, y] = bfs.front();bfs.pop();image[x][y] = newcolor;// 4. 将对头元素邻近元素根据要求加入队列中,达到bfs效果for(int i = 0; i < 4; ++i){int newx = x + dx[i], newy = y + dy[i];if(newx >= 0 && newy >= 0 && newx < image.size() && newy < image[newx].size() && image[newx][newy] == oldcolor)bfs.push({newx, newy});}}return image;}
};

在这里插入图片描述

200. 岛屿数量

200. 岛屿数量

​ 给你一个由 '1'(陆地)和 '0'(水)组成的的二维网格,请你计算网格中岛屿的数量。

​ 岛屿总是被水包围,并且每座岛屿只能由水平方向和/或竖直方向上相邻的陆地连接形成。

​ 此外,你可以假设该网格的四条边均被水包围。

示例 1:

输入:grid = [["1","1","1","1","0"],["1","1","0","1","0"],["1","1","0","0","0"],["0","0","0","0","0"]
]
输出:1

示例 2:

输入:grid = [["1","1","0","0","0"],["1","1","0","0","0"],["0","0","1","0","0"],["0","0","0","1","1"]
]
输出:3

提示:

  • m == grid.length
  • n == grid[i].length
  • 1 <= m, n <= 300
  • grid[i][j] 的值为 '0''1'

解题思路:广度优先遍历

​ 这道题具体思路可以参考递归专题中的笔记,这里不再赘述!

​ 使用 bfs 来解决问题,其实思路都是一样的,以每个元素为起点找寻所有的岛屿,并且记录数量,当遇到 1 的时候,则将记录数量增加,然后进行广度优先遍历,将 1 修改为 0。然后继续遍历二维数组直到岛屿都找到了为止!

​ 这里我们采用的修改方式是直接修改原数组,如果不直接修改原数组也是可以的,就得用一个 used 数组来判断是否走过,都是一样的套路,这里就不演示了!

​ 此外,我们将 {i, j} 邻近的符合要求的节点添加到队列中时,就要将其从 1 改为 0,这样子可以减少许多不必要的重复遍历操作,并且不这么做的话,这道题也是会超时的!

class Solution {
private:int dx[4] = { 0, 0, 1, -1 };int dy[4] = { -1, 1, 0, 0 };
public:int numIslands(vector<vector<char>>& grid) {// 以每个元素为起点找寻所有的岛屿,并且记录数量int ret = 0;for(int i = 0; i < grid.size(); ++i){for(int j = 0; j < grid[i].size(); ++j){if(grid[i][j] == '1'){ret++;bfs(grid, i, j); // 进行广度优先遍历,将'1'修改为'0'}}}return ret;}void bfs(vector<vector<char>>& grid, int i, int j){queue<pair<int, int>> qe;qe.push({i, j});grid[i][j] = '0';while(!qe.empty()){auto [x, y] = qe.front();qe.pop();for(int k = 0; k < 4; ++k){int newx = x + dx[k], newy = y + dy[k];if(newx >= 0 && newy >= 0 && newx < grid.size() && newy < grid[newx].size() && grid[newx][newy] == '1'){qe.push({newx, newy});grid[newx][newy] = '0'; // 提前将邻近节点改为'0',可以减少许多不必要的重复}}}}
};

在这里插入图片描述

相关文章:

【广度优先搜索】图像渲染 岛屿数量

文章目录 733. 图像渲染解题思路&#xff1a;BFS200. 岛屿数量解题思路&#xff1a;广度优先遍历 733. 图像渲染 733. 图像渲染 ​ 有一幅以 m x n 的二维整数数组表示的图画 image &#xff0c;其中 image[i][j] 表示该图画的像素值大小。 ​ 你也被给予三个整数 sr , sc 和…...

Rust学习总结之-枚举

枚举是一个很多语言都有的功能&#xff0c;不过不同语言中其功能各不相同但是要表达的意思是一致的&#xff0c;枚举就是对于一个事物可以穷举出所有可能得值。比如说人的性别就可以用枚举&#xff0c;男人和女人两种。下面我们来学习Rust中的枚举。 一&#xff1a;枚举定义 …...

Linux下用route命令修改默认网关,不用重启网络

在Linux系统中&#xff0c;可以使用route命令来修改默认网关&#xff0c;而不需要重启网络。 下面是使用route命令修改默认网关的步骤&#xff1a; 打开终端窗口&#xff0c;以root用户或拥有sudo权限的用户身份登录。 使用以下命令查看当前的路由表信息&#xff1a; route…...

Datawhale 数学建模导论二 笔记5 多模数据与智能模型

主要涉及到的知识点有&#xff1a; 数字图像处理与计算机视觉 计算语言学与自然语言处理 数字信号处理与智能感知 10.1 数字图像处理与计算机视觉 视觉信息是我们第一种非常规的数据模式&#xff0c;在Python当中可以使用opencv处理数字图像&#xff0c;并提取出视觉特征用…...

【练习】【贪心】力扣1005. K 次取反后最大化的数组和

题目 1005 K 次取反后最大化的数组和 给你一个整数数组 nums 和一个整数 k &#xff0c;按以下方法修改该数组&#xff1a; 选择某个下标 i 并将 nums[i] 替换为 -nums[i] 。 重复这个过程恰好 k 次。可以多次选择同一个下标 i 。 以这种方式修改数组后&#xff0c;返回数组 可…...

python学习七

作用域&#xff1a; 在编程语言中定义变量的可见性和生命周期的规则集合。它决定了在程序中的哪些位置可以访问或引用某个变量 1.全局作用域&#xff1a; 全局作用域是指在整个程序中都可见的变量。在函数外 部定义的变量通常具有全局作用域&#xff0c;在任何地方都可以访问和…...

安全运营的“黄金4小时“:如何突破告警疲劳困局

在当今复杂多变的网络安全环境中&#xff0c;安全团队面临着前所未有的挑战。尤其是面对高级持续性威胁&#xff08;APT&#xff09;时&#xff0c;最初的“黄金4小时”成为决定成败的关键窗口。在这段时间内&#xff0c;快速而准确地响应可以极大地降低损失&#xff0c;然而&a…...

本地部署Embedding模型API服务的实战教程

大家好,我是herosunly。985院校硕士毕业,现担任算法研究员一职,热衷于大模型算法的研究与应用。曾担任百度千帆大模型比赛、BPAA算法大赛评委,编写微软OpenAI考试认证指导手册。曾获得阿里云天池比赛第一名,CCF比赛第二名,科大讯飞比赛第三名。授权多项发明专利。对机器学…...

数据结构:二叉树的链式结构及相关算法详解

目录 一.链式结构的实现 1.二叉树结点基本结构&#xff0c;初始化与销毁&#xff1a; 二.链式结构二叉树的几种遍历算法 1.几种算法的简单区分&#xff1a; 2.前序遍历&#xff1a; 3.中序遍历&#xff1a; 4.后序遍历&#xff1a; 5.层序遍历&#xff08;广度优先遍历B…...

10.【线性代数】—— 四个基本子空间

十、 四个基本子空间 1. 列空间 C ( A ) C(A) C(A) in R m R^m Rm2. 零空间 N ( A ) N(A) N(A) in R n R^n Rn3. 行空间 C ( A T ) C(A^T) C(AT) in R n R^n Rn4. 左零空间 N ( A T ) N(A^T) N(AT) in R m R^m Rm综述5. 新的向量空间 讨论矩阵 A m ∗ n A_{m*n} Am∗n​…...

计算机黑皮书191本分享pdf

“黑皮书”通常指的是由机械工业出版社出版的计算机科学丛书。这些书籍的封面通常是黑色的&#xff0c;因此得名“黑皮书”。这些书籍涵盖了计算机科学的各个领域&#xff0c;包括操作系统、计算机网络、软件工程、编译原理、数据库等。 获取链接&#xff1a;链接:https://pan…...

MySQL Connector/J下载

MySQL Connector/J下载 下载mysql驱动jar包。 官网&#xff1a;https://downloads.mysql.com/archives/c-j/ 我下载的是8.0.33&#xff0c;下载的时候要注意与MySQL的版本对应。...

AIGC生图产品PM必须知道的Lora训练知识!

hihi&#xff0c;其实以前在方向AIGC生图技术原理和常见应用里面已经多次提到Lora的概念了&#xff0c;但是没有单独拿出来讲过&#xff0c;今天就耐心来一下&#xff01; &#x1f525; 一口气摸透AIGC文生图产品SD&#xff08;Stable Diffusion&#xff09;&#xff01; 一、…...

【Swift 算法实战】城市天际线问题解法

网罗开发 &#xff08;小红书、快手、视频号同名&#xff09; 大家好&#xff0c;我是 展菲&#xff0c;目前在上市企业从事人工智能项目研发管理工作&#xff0c;平时热衷于分享各种编程领域的软硬技能知识以及前沿技术&#xff0c;包括iOS、前端、Harmony OS、Java、Python等…...

易错点abc

在同一个输入流上重复创建Scanner实例可能会导致一些问题&#xff0c;包括但不限于输入流的混乱。尤其是在处理标准输入&#xff08;System.in&#xff09;时&#xff0c;重复创建Scanner对象通常不是最佳实践&#xff0c;因为这可能导致某些输入数据丢失或者顺序出错。 为什么…...

C++ 正则表达式分组捕获入门指南

在 C 中&#xff0c;正则表达式&#xff08;regex&#xff09;是一种用于匹配字符串模式的强大工具。正则表达式不仅能帮助你查找符合特定模式的字符&#xff0c;还能捕获匹配的子字符串&#xff08;即分组捕获&#xff09;。这篇文章将介绍 C 正则表达式中的分组捕获机制&…...

AI人工智能机器学习之降维和数据压缩

1、概要 本篇学习AI人工智能机器学习之降维和数据压缩&#xff0c;以主成分分析&#xff08;PCA, Principal Component Analysis&#xff09;为例&#xff0c;从代码层面讲述机器学习中的降维和数据压缩。 2、降维和数据压缩 - 简介 在机器学习和数据分析中&#xff0c;降维&…...

17 款电脑压缩工具详解及下载指南(2025 年最新版)

在数字时代,文件压缩是日常工作与生活中不可或缺的操作。无论是视频剪辑师压缩视频以便上传,还是普通用户节省存储空间,一款优质的压缩软件都能极大提升效率。本文将详细介绍 17 款热门电脑压缩软件,涵盖它们的特点、下载地址及适用场景,助你找到最适合自己的工具。 一、…...

DeepSeek开源周Day5压轴登场:3FS与Smallpond,能否终结AI数据瓶颈之争?

2025年2月28日&#xff0c;DeepSeek开源周迎来了第五天&#xff0c;也是本次活动的收官之日。自2月24日启动以来&#xff0c;DeepSeek团队以每天一个开源项目的节奏&#xff0c;陆续向全球开发者展示了他们在人工智能基础设施领域的最新成果。今天&#xff0c;他们发布了Fire-F…...

ROS2软件调用架构和机制解析:Publisher创建

术语 DDS (Data Distribution Service): 用于实时系统的数据分发服务标准&#xff0c;是ROS 2底层通信的基础RMW (ROS Middleware): ROS中间件接口&#xff0c;提供与具体DDS实现无关的抽象APIQoS (Quality of Service): 服务质量策略&#xff0c;控制通信的可靠性、历史记录、…...

Mapbox Studio Classic核心功能解析:CartoCSS与矢量瓦片技术详解

Mapbox Studio Classic核心功能解析&#xff1a;CartoCSS与矢量瓦片技术详解 【免费下载链接】mapbox-studio-classic 项目地址: https://gitcode.com/gh_mirrors/ma/mapbox-studio-classic Mapbox Studio Classic是一款强大的桌面地图设计工具&#xff0c;专为创建专业…...

Resend + Cloudflare 域名邮箱搭建实战:避坑指南与 Foxmail 配置全解析

一、 前言&#xff1a;为什么选择这套方案&#xff1f;在互联网上混&#xff0c;专属域名邮箱&#xff08;如 adminyourdomain.com&#xff09;就是你的“赛博身份证”。相比于使用 xxxxqq.com&#xff0c;它能瞬间提升你的职业感与信任度。目前最稳、最快且零成本的配置方案是…...

Wand-Enhancer:3步解锁WeMod专业版功能的完整用户指南

Wand-Enhancer&#xff1a;3步解锁WeMod专业版功能的完整用户指南 【免费下载链接】Wand-Enhancer Advanced UX and interoperability extension for Wand (WeMod) app 项目地址: https://gitcode.com/gh_mirrors/we/Wand-Enhancer 你是否厌倦了WeMod免费版的种种限制&a…...

将 Claude Code 的 API 请求无缝迁移至 Taotoken 平台

&#x1f680; 告别海外账号与网络限制&#xff01;稳定直连全球优质大模型&#xff0c;限时半价接入中。 &#x1f449; 点击领取海量免费额度 将 Claude Code 的 API 请求无缝迁移至 Taotoken 平台 如果你正在使用 Claude Code 作为编程助手&#xff0c;并且希望将其后端 AP…...

洛雪音乐音源:从零到一的音乐聚合解决方案实战指南

洛雪音乐音源&#xff1a;从零到一的音乐聚合解决方案实战指南 【免费下载链接】lxmusic- lxmusic(洛雪音乐)全网最新最全音源 项目地址: https://gitcode.com/gh_mirrors/lx/lxmusic- 你是否曾经为了找到一首歌而辗转于多个音乐平台&#xff1f;是否因为音质选择有限而…...

DS4Windows:让PlayStation手柄在Windows上焕发新生

DS4Windows&#xff1a;让PlayStation手柄在Windows上焕发新生 【免费下载链接】DS4Windows Like those other ds4tools, but sexier 项目地址: https://gitcode.com/gh_mirrors/ds/DS4Windows 你是否曾想过&#xff0c;为什么心爱的PlayStation手柄在PC上总是表现得像个…...

告别AssetBundle!用Unity Addressables实现资源热更,我踩过的坑都帮你填平了

从AssetBundle到Addressables&#xff1a;Unity资源热更的现代化迁移指南第一次接触Unity Addressables时&#xff0c;我正被AssetBundle的各种问题折磨得焦头烂额。那是一个周五的深夜&#xff0c;项目即将上线&#xff0c;却因为AssetBundle的依赖关系混乱导致热更新失败。在…...

华硕笔记本终极优化指南:如何用G-Helper轻量级工具全面提升使用体验

华硕笔记本终极优化指南&#xff1a;如何用G-Helper轻量级工具全面提升使用体验 【免费下载链接】g-helper Lightweight Armoury Crate alternative for Asus laptops with nearly the same functionality. Works with ROG Zephyrus, Flow, TUF, Strix, Scar, ProArt, Vivobook…...

别再折腾VMware Tools了!用FileZilla+SSH搞定Windows与Ubuntu虚拟机文件互传(保姆级教程)

告别VMware Tools烦恼&#xff1a;SSHFileZilla实现跨平台文件传输全攻略 每次在Windows和Ubuntu虚拟机之间传输文件时&#xff0c;VMware Tools总是给你带来各种麻烦&#xff1f;安装失败、兼容性问题、功能受限...这些问题我都经历过。今天我要分享的是一种更稳定、更通用的…...

手把手教你用Linux命令‘偷看’UEFI启动日志,排查系统启动失败问题

实战指南&#xff1a;用Linux命令深度解析UEFI启动日志当你的Linux系统卡在启动界面&#xff0c;或是反复重启无法进入桌面时&#xff0c;那种焦虑感每个运维人员都深有体会。UEFI启动过程就像一场精心编排的交响乐&#xff0c;任何一个环节出错都可能导致系统启动失败。本文将…...