【leetcode994】腐烂的橘子(BFS)

这篇具有很好参考价值的文章主要介绍了【leetcode994】腐烂的橘子(BFS)。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

一、题目

【leetcode994】腐烂的橘子(BFS),LeetCode,# BFS和DFS,算法,BFS,leetcode

【leetcode994】腐烂的橘子(BFS),LeetCode,# BFS和DFS,算法,BFS,leetcode文章来源地址https://www.toymoban.com/news/detail-826952.html

二、思路

  • 首先将所有烂橘子入队,然后常规BFS遍历,注意while的截止条件除了队列为空,新鲜橘子数量大于0(没新鲜橘子也没必要继续遍历,保证时间计算的正确性),这两者一个不满足就可以停止
  • 每分钟进行一次【腐烂扩散】,使用BFS对二维图进行遍历,注意和二叉树的层次遍历不一样(二叉树则是只有一个根节点,这里可能有多个腐烂橘子-根节点)。
  • auto [x, y] = q.front()是C++17引入的新语法,结构化绑定,可以从数组、元组或结构体中一次性解包多个值,并将他们绑定到多个变量上,比如这里就是声明了xy变量,然后将这2个变量绑定到元组中。如果不这么使用,可以直接通过firstsecond访问pair元素的数值。
  • auto& dir: directions是C++11的语法,&表示引用,直接auto dir则是按值访问,前者可以避免不必要的复制,并且允许你修改容器的容器。

三、代码

class Solution {
public:
    int orangesRotting(vector<vector<int>>& grid) {
        int m = grid.size();
        int n = grid[0].size();
        //存储上下左右的坐标方位
        vector<pair<int, int>> directions = {{0,1}, {0,-1}, {1,0},{-1,0}};
        int fresh_num = 0;
        //创建队列,存储腐烂的橘子二维坐标位置
        queue<pair<int, int>>q;
        for(int i=0; i < m;i++){
            for(int j=0; j < n; j++){
                if (grid[i][j] == 1)
                    fresh_num += 1;
                //将所有烂橘子入队列
                if (grid[i][j] == 2)
                    q.push({i, j});
            }
        }
        int minutes = 0;
        //烂橘子队列中没有橘子后则停止
        while(!q.empty() && fresh_num > 0){
            int q_num = q.size();
            //所有的烂橘子同时开始干活
            for(int i=0; i< q_num; i++){ 
                //队首元素
                pair<int, int>one = q.front();
                q.pop(); //出队
                int x = one.first;
                int y = one.second;
                //遍历当前位置的上下左右
                for(auto& dir: directions){
                    int nx = x + dir.first;
                    int ny = y + dir.second;
                    if(nx >= 0 && nx < m && ny >= 0 && ny < n && grid[nx][ny] == 1){ //如果是新鲜橘子
                        grid[nx][ny] = 2;
                        q.push({nx, ny});
                        fresh_num -= 1;
                    }
                }
            }
            minutes += 1;
        }
        return fresh_num == 0?minutes:-1;
    }
};

到了这里,关于【leetcode994】腐烂的橘子(BFS)的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • LeetCode_BFS_DFS_中等_1376.通知所有员工所需的时间

    公司里有 n 名员工,每个员工的 ID 都是独一无二的,编号从 0 到 n - 1。公司的总负责人通过 headID 进行标识。 在 manager 数组中,每个员工都有一个直属负责人,其中 manager[i] 是第 i 名员工的直属负责人。对于总负责人,manager[headID] = -1。题目保证从属关系可以用树结构显示。

    2024年02月02日
    浏览(21)
  • LeetCode 865. Smallest Subtree with all the Deepest Nodes【树,DFS,BFS,哈希表】1534

    本文属于「征服LeetCode」系列文章之一,这一系列正式开始于2021/08/12。由于LeetCode上部分题目有锁,本系列将至少持续到刷完所有无锁题之日为止;由于LeetCode还在不断地创建新题,本系列的终止日期可能是永远。在这一系列刷题文章中,我不仅会讲解多种解题思路及其优化,

    2024年02月09日
    浏览(30)
  • 算法沉淀——多源 BFS(leetcode真题剖析)

    多源 BFS 是指从多个源点同时进行广度优先搜索的算法。在传统的 BFS 中,我们通常从一个起始点开始,逐层遍历所有的相邻节点。而在多源 BFS 中,我们可以同时从多个源点开始,从这些源点出发,逐层向外扩展,直到达到目标或者遍历完整个图。 多源 BFS 可以用于解决一些

    2024年02月19日
    浏览(36)
  • 算法沉淀——BFS 解决 FloodFill 算法(leetcode真题剖析)

    BFS(广度优先搜索)解决 Flood Fill 算法的基本思想是通过从起始点开始,逐层向外扩展,访问所有与起始点相连且具有相同特性(颜色等)的区域。在 Flood Fill 中,通常是通过修改图像的像素颜色。 下面是 BFS 解决 Flood Fill 算法的步骤: 初始化: 将起始点的颜色修改为新的

    2024年02月20日
    浏览(29)
  • 算法沉淀——BFS 解决拓扑排序(leetcode真题剖析)

    Breadth-First Search (BFS) 在拓扑排序中的应用主要是用来解决有向无环图(DAG)的拓扑排序问题。拓扑排序是对有向图中所有节点的一种线性排序,使得对于每一条有向边 (u, v),节点 u 在排序中都出现在节点 v 的前面。如果图中存在环路,则无法进行拓扑排序。 BFS 解决拓扑排序

    2024年02月21日
    浏览(29)
  • 算法沉淀——BFS 解决最短路问题(leetcode真题剖析)

    BFS (广度优先搜索)是解决最短路径问题的一种常见算法。在这种情况下,我们通常使用BFS来查找从一个起始点到目标点的最短路径。 具体步骤如下: 初始化: 从起始点开始,将其放入队列中,并标记为已访问。 BFS遍历: 不断从队列中取出顶点,然后探索与该顶点相邻且

    2024年02月20日
    浏览(32)
  • 【LeetCode 算法】Unique Paths III 不同路径 III 暴力DFS

    在二维网格 grid 上,有 4 种类型的方格: 1 表示起始方格。且只有一个起始方格。 2 表示结束方格,且只有一个结束方格。 0 表示我们可以走过的空方格。 -1 表示我们无法跨越的障碍。 返回在四个方向(上、下、左、右)上行走时,从起始方格到结束方格的不同路径的数目

    2024年02月14日
    浏览(37)
  • 拓扑排序算法 -- dfs、bfs

    210. 课程表 II 该题用到「拓扑排序」的算法思想,关于拓扑排序,直观地说就是,让你把⼀幅图「拉平」,⽽且这个「拉平」的图⾥⾯,所有箭头⽅向都是⼀致的,⽐如上图所有箭头都是朝右的。 很显然,如果⼀幅有向图中存在环,是⽆法进⾏拓扑排序的,因为肯定做不到所

    2024年02月10日
    浏览(28)
  • 算法-图BFS/DFS-单词接龙

    https://leetcode-cn.com/problems/number-of-islands 给定两个单词(beginWord 和 endWord)和一个字典,找到从 beginWord 到 endWord 的最短转换序列的长度。转换需遵循如下规则: 每次转换只能改变一个字母。 转换过程中的中间单词必须是字典中的单词。 说明: 如果不存在这样的转换序列,返回

    2024年02月10日
    浏览(34)
  • 算法回忆录——DFS与BFS

    拿迷宫(二维,上下左右四个方向,入口在左方)来举例,一开始从入口出发,一直往右走,如果遇到了路口,就记录下该路口有几条路可以走,然后选择一条走下去,如果走下去又遇到了一个路口,那么又记录下这个路口有几条路口可以走,然后返回第一个路口,选择未走

    2024年01月21日
    浏览(31)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包