一命通关广度优先遍历

news2025/1/16 8:16:49


前言

在这篇文章之前,已对非线性结构遍历的另一种方法——深度优先遍历进行了讲解,其中很多概念词都是共用的。为了更好的阅读体验,最好先在掌握或起码了解dfs的基础上,再来阅读本文章,否则因为会有很多概念词看不明白而降低阅读体验。

一命通关深度优先遍历-CSDN博客icon-default.png?t=N7T8https://blog.csdn.net/qq_74260823/article/details/136819359?spm=1001.2014.3001.5501


广度优先遍历

简介

与dfs不同,bfs是先遍历完一层的所有结点,再往下一层进发。bfs先踏完第一步能到达的所有结点,然后再遍历第二步才可以到达的结点,一直遍历到最远才可以到达的结点,完成遍历。

  • 但是,同一个结点可能会在两个范围中:

  •  也可能会有回头路:

不过,所有的结点只能被遍历一次,所以,大部分bfs问题,都需要配有一个标记数组。

实现方法

我们想知道第二步才可以到达的结点,最直接的想法就是在找到所有第一步就能到达的情况下,再走一步,就是第二步才可以到达的结点。为了实现这个思想,即通过上一层去找下一层的结点,最直接的实现方法就是采用两个数组:

我们遍历上层数组的所有元素,然后通过这些元素找到他们相邻的结点,就是下一层元素的所有元素。
然后,继续往下遍历,将上层数组清空,与下层数组交换,如此反复交替,一直到走到最后一层。

不过,这种方法可以优化成一个队列实现: 

将上一层的元素弹出的同时,将下一层的元素带入队列尾,这种方法思想在二叉树的层序遍历中已经详细讲过了,就不再重复说明了。

因为解题思路和公式非常非常套路化,所以直接上题目:

200. 岛屿数量 - 力扣(LeetCode)

简单翻译一下题目,就是找到有几个不挨着的1区块。
而解法也很简单,我们遍历所有元素,当遇到1时,就采用bfs或者dfs将相邻的1全部标记一下,我们这里用bfs来实现。

首先还是在dfs里一模一样的:

  1. 位移数组drow和dcol
  2. 主函数部分,遍历每个源头
  3. 判断边界条件

而唯一和dfs不一样的,也只不过是dfs和bfs函数中的一小部分

class Solution {
    int m,n;
    vector<vector<bool>> record;
    int drow[4]={1,-1,0,0};
    int dcol[4]={0,0,1,-1};
    int ret;//与dfs一模一样
    typedef pair<int,int> ii;
public:
    void bfs(vector<vector<char>>& grid,int i,int j)
    {
        queue<ii> que;
        que.push({i,j});
        record[i][j]=true;

        while(!que.empty())
        {
            auto [row,col]=que.front();que.pop();
            for(int i=0;i<4;i++)
            {
                int newrow=row+drow[i];
                int newcol=col+dcol[i];
                if(newrow>=0&&newrow<m&&newcol>=0&&newcol<n&&
                record[newrow][newcol]==false&&grid[newrow][newcol]=='1')//与dfs一模一样
                {
                    que.push({newrow,newcol});
                    record[newrow][newcol]=true;
                }
            }
        }
    }
    int numIslands(vector<vector<char>>& grid) {
        m=grid.size();
        n=grid[0].size();
        record.resize(m,vector<bool>(n));

        for(int i=0;i<m;i++)
        {
            for(int j=0;j<n;j++)
            {
                if(record[i][j]==false&&grid[i][j]=='1')
                {
                    bfs(grid,i,j);
                    ret++;
                }
            }
        }

        return ret;
    }//整个主函数也与dfs一模一样
};

所以,bfs的公式也很明了,和dfs大差不差:

公式

class Solution {
    int dx[4] = { 0,0,1,-1 };
    int dy[4] = { 1,-1,0,0 };//方向数组
    vector<vector<bool>> record;//标记数组
    int m, n;//矩阵长宽
    typedef pair<int, int> ii;
public:
    void bfs(vector<vector<int>>& grid, int i, int j)
    {
        queue<ii> que;//创建bfs用的队列
        que.push({ i , j });//将源头插入队列中

        while (!que.empty())
        {
            auto [row, col] = que.front();//取队头元素

            for (int i = 0; i < 4; i++)
            {
                int nextrow = row + dy[i];
                int nextcol = col + dx[i];//新的坐标
                if (nextrow >= 0 && nextrow < m && nextcol >= 0 && nextcol < n//不越界
                    && record[nextrow][nextcol] == false//没有走回头路
                    && grid[nextrow][nextcol]...)//满足题目要求
                {
                    record[nextrow][nextcol] = true;
                    que.push({ nextrow,nextcol });
                }
            }
        }

    }
    ... main(vector<vector<int>>& grid) {
        m = grid.size();
        n = grid[0].size();
        record.resize(m, vector<bool>(n));

        //遍历每一个源头
        for (int i = 0; i < m; i++)
        {
            for (int j = 0; j < n; j++)
            {
                if (record[i][j]==false&&grid[i][j] != 0)
                {
                    record[i][j] = true;
                    bfs(grid, i, j);
                }
            }
        }
    }
};

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1534343.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Spring框架(下半部分 -AOP)

1.2 AOP相关的概念 1.2.1 AOP的概述 什么是AOP的技术&#xff1f; 在软件业&#xff0c;AOP为Aspect Oriented Programming的缩写&#xff0c;意为&#xff1a;面向切面编程 AOP是一种编程范式&#xff0c;隶属于软工范畴&#xff0c;指导开发者如何组织程序结构AOP最早由AO…

【开源-土拨鼠充电系统】鸿蒙 HarmonyOS 4.0 App+微信小程序+云平台

✨本人自己开发的开源项目&#xff1a;土拨鼠充电系统 ✨踩坑不易&#xff0c;还希望各位大佬支持一下&#xff0c;在Gitee或GitHub给我点个 Start ⭐⭐&#x1f44d;&#x1f44d; ✍Gitee开源项目地址&#x1f449;&#xff1a;https://gitee.com/cheinlu/groundhog-charging…

多维时序 | MATLAB实现BiTCN-selfAttention自注意力机制结合双向时间卷积神经网络多变量时间序列预测

多维时序 | MATLAB实现BiTCN-selfAttention自注意力机制结合双向时间卷积神经网络多变量时间序列预测 目录 多维时序 | MATLAB实现BiTCN-selfAttention自注意力机制结合双向时间卷积神经网络多变量时间序列预测预测效果基本介绍模型描述程序设计参考资料 预测效果 基本介绍 1.M…

深度学习_20_卷积中的填充与步幅

如果图片本身比较小&#xff0c;卷积之后输出也会很小&#xff0c;那么可以在图片与卷积核相乘之前先填充一下&#xff0c;让输出为预期大小 一般填充后输入&#xff0c;输出相同 当图片比较大的时候&#xff0c;如果利用卷积核去得到我们想要的大小的话&#xff0c;得用到多层…

Linux虚拟主机如何快速卸载一键安装的网站程序

接到一位用户发送的请求帮助&#xff0c;想要卸载通过Softaculous一键安装的网站程序&#xff0c;但是没有找到地方&#xff0c;根据与该用户的沟通得知是一个小白用户&#xff0c;想要自己搭建一个博客类的网站&#xff0c;了解到Hostease 有适合新用户并且带管理面板的产品Li…

Nginx:部署及配置详解(linux)

Nginx&#xff1a;部署及配置详解&#xff08;linux&#xff09; 1、nginx简介2、安装编译工具及库文件3、安装 pcre4、nginx安装5、nginx配置文件nginx.conf组成6、nginx配置实例-反向代理7、nginx 配置实例-负载均衡 &#x1f496;The Begin&#x1f496;点点关注&#xff0c…

代码随想录算法训练营第day53|1143.最长公共子序列 、 1035.不相交的线、 53. 最大子序和 动态规划

目录 1143.最长公共子序列 1035.不相交的线 53. 最大子序和 1143.最长公共子序列 力扣题目链接(opens new window) 给定两个字符串 text1 和 text2&#xff0c;返回这两个字符串的最长公共子序列的长度。 一个字符串的 子序列 是指这样一个新的字符串&#xff1a;它是由原…

【嵌入式——QT】QT Charts

【嵌入式——QT】QT Charts 概述Qt提供的坐标轴类QChartQLineSeriesQValueAxis常见图表及用到的序列类图示代码示例 概述 QT Charts模块是一组易于使用的图表组件&#xff0c;它基于Qt的Graphics View架构&#xff0c;其核心组件是QChartView和QChart&#xff0c;QChartView父…

【傻瓜文档】鼎利测试软件Pilot Pioneer-② 数据分析与处理功能

数据分析与处理功能 数据导入、解码 ① 导入数据 两种方式: 添加新数据导入历史数据不需要的数据可以移除 ② 数据解码 正式格式的数据可以重解码,例如Rcu、dcf等等,尽量选择正式数据。 两种方式: 选中数据,右键选择重解码双击信令重解码后的文件会生成为DitIB的文件…

第二节 动态面板使用实例操作

1、使用元件库 2、使用添加元件库 1.添加外部元件库 2.自做元件库 保存为*.rplib文件&#xff0c;就可以给其他项目使用了。 3、制作母板 1、新建模版 2、导入旧模版 此操作主要用于想使用原型中已经做好母版&#xff0c;有时直接粘贴又粘贴不成功&#xff0c;需要按下面方式…

MQTT和Modbus的物联网网关协议区别分析

MQTT和Modbus的物联网网关协议区别分析 MQTT&#xff08;Message Queuing Telemetry Transport&#xff09;与Modbus是两种广泛应用在物联网环境中的通信协议&#xff0c;它们各自具有独特的优势和适用场景&#xff0c;下面将从多个维度对这两种网关协议进行详细区别分析。 首…

ShardingSphere+JPA+Druid实现分表操作

要在SpringBoot项目中实现分表操作&#xff0c;本文使用的是ShardingSphereJPADruid实现。过程中出现问题记录一下。 准备MySQL数据库表 这里准备的是一张主表test_cost&#xff0c;两张从表test_cost_0和test_cost_1&#xff0c;结构需要相同&#xff0c;主表只是声明了表结构…

3.21 day2 QT

自由发挥登录窗口的应用场景&#xff0c;实现一个登录窗口界面 要求: 1.需要使用Ui界面文件进行界面设计 2.ui界面上的组件相关设置&#xff0c;通过代码实现 3需要添加适当的动图

【C++】—— 装饰器模式

目录 &#xff08;一&#xff09;什么是装饰器模式 &#xff08;二&#xff09;为什么要使用装饰器模式 &#xff08;三&#xff09;装饰器模式的实现步奏 &#xff08;四&#xff09;代码示例 &#xff08;五&#xff09;装饰器模式优缺点 &#xff08;一&#xff09;什么…

解决GNURadio自定义C++ OOT块-导入块时报错问题

文章目录 前言一、问题描述二、解决方法1、安装依赖2、配置环境变量3、重新编译及安装三、结果1、添加结果2、运行结果前言 本文记录在 GNURadio 自定义 C++ OOT 块后导入块时报错 AttributeError: module myModule has no attribute multDivSelect。 一、问题描述 参考官方教…

css使用变量

vue3单文件SFC新特性在css里可以使用变量&#xff0c;具体使用如下&#xff1a; <template><div class"home-view"><span>测试</span><p>测试2</p></div> </template><script setup lang"ts"> imp…

Web Service接口测试

Web service 接口测试 一. web Service概念 Web service使用与平台和编程语言无关的方式进行通讯的一项技术, web service 是一个接口, 他描述了一组可以在网络上通过标准的XML消息传递访问的操作,它基于xml语言协议来描述要执行的操作或者要与另外一个web 服务交换数据, 一组…

Leetcode 994. 腐烂的橘子

心路历程&#xff1a; 一开始以为和刚做过的岛屿问题很像&#xff0c;只不过是把岛屿问题换成BFS去做&#xff0c;然后再加上一些计数的规则。结果做完后发现只能通过一半左右的测试用例&#xff0c;发现有一个逻辑错误在于&#xff0c;当腐烂的橘子位于两端时&#xff0c;可以…

代码随想录算法训练营第day25|216.组合总和III、 17.电话号码的字母组合

216.组合总和III 力扣题目链接 (opens new window) 找出所有相加之和为 n 的 k 个数的组合。组合中只允许含有 1 - 9 的正整数&#xff0c;并且每种组合中不存在重复的数字。 说明&#xff1a; 所有数字都是正整数。解集不能包含重复的组合。 示例 1: 输入: k 3, n 7 输…

转置卷积(transposed-conv)

一、什么是转置卷积 1、转置卷积的背景 通常&#xff0c;对图像进行多次卷积运算后&#xff0c;特征图的尺寸会不断缩小。而对于某些特定任务 (如图像分割和图像生成等)&#xff0c;需将图像恢复到原尺寸再操作。这个将图像由小分辨率映射到大分辨率的尺寸恢复操作&#xff0c…