力扣hot100:994. 腐烂的橘子(多源BFS)

在这里插入图片描述
     这是一个典型的多源BFS问题,如果初学数据结构的同学,可能第一次不能想到,但是如果做过一次应该就能运用了。
     主要思路大概是初始时,多个点进入队列然后进行BFS。将某一等价集合视作同一个起始点(超级源点),先将此源点入队,再一层一层向外扩张。相当于这些初始出队的源点在整个问题中地位等价。另外还可以视作不同的起点同时进行BFS操作,而不需要依次作为起点依次BFS,有时写在一起更方便。

腐烂的橘子:

     由于这里腐烂的橘子应该是同时向外感染腐烂的,如果分不同次进行BFS问题会很棘手,但是如果将腐烂的橘子进行多源BFS,则最后一层实际上就是最后腐烂的橘子,它腐烂的时间就是整个问题的答案。
     这里使用tuple存储顶点信息,很方便。
在这里插入图片描述

class Solution {
public:
    int orangesRotting(vector<vector<int>>& grid) {
        queue<tuple<int,int,int> > q;
        int num=0;//记录剩余新鲜橘子个数
        m=grid.size(),n=grid[0].size();
        
        for(int i=0;i<m;++i)
            for(int j=0;j<n;++j)
                if(grid[i][j]==2){
                    q.push({i,j,0});//存放腐坏橘子位置以及它腐坏时经过的时间
                }else if(grid[i][j]) num++;
            
        int ans=-1;
        while(!q.empty()&&num){
            int x=get<0>(q.front());
            int y=get<1>(q.front());
            ans=get<2>(q.front());  q.pop();//时间一定为不减序列
            for(int k=0;k<4;++k){
                int i=dx[k],j=dy[k];
                if(check(x+i,y+j)&&grid[x+i][y+j]==1){
                    grid[x+i][y+j]=2;
                    q.push(make_tuple(x+i,y+j,ans+1));
                    --num;
                }
            }
        }
        if(num!=0) return -1;
        return ans+1;//ans+1是答案的原因是:当num==0时,已经没有腐坏橘子可以更新了,会直接break,但是此时最外层福坏橘子的ans并未被记录成答案
    }
private:
    bool check(int x,int y){
        if(x>=0&&x<m&&y>=0&&y<n) return true;
        return false;
    }
    int m,n;
    const int dx[4]={0,1,0,-1};
    const int dy[4]={-1,0,1,0};
};

许久没做图论问题,把方向写错了,感觉是惯性思维了,这里记录下来防止以后又写错。写成了这样:

const int dx[4]={0,1,0,-1};
const int dy[4]={-1,0,1,0};
for(int i:dx)//wrong//wrong//wrong//wrong//wrong//wrong//wrong
	for(int j:dy){//wrong//wrong//wrong//wrong//wrong//wrong//wrong
		//巴拉巴拉//wrong
	}//wrong

上述写法方向一共有4*4=16种,其中8个是正常的顶点四周的8个方向(左上,左,左下,上,下,右上,右,右下,对于每一个x方向遍历y),8个是无用的重复方向。而实际上方向只有四个,dx[i]和dy[i]组合形成一个方向,以下是正确方式

const int dx[4]={0,1,0,-1};
const int dy[4]={-1,0,1,0};
for(int k=0;k<4;++k){//正确打开方式,遍历四个方向
	i=x+dx[k];
	j=y+dy[k];
	g[i][j]=0;	
}

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

阿里二面:Java中锁的分类有哪些?你能说全吗?

引言 在多线程并发编程场景中&#xff0c;锁作为一种至关重要的同步工具&#xff0c;承担着协调多个线程对共享资源访问秩序的任务。其核心作用在于确保在特定时间段内&#xff0c;仅有一个线程能够对资源进行访问或修改操作&#xff0c;从而有效地保护数据的完整性和一致性。…

kvm虚拟化

kvm虚拟化 1. 虚拟化介绍 虚拟化是云计算的基础。简单的说&#xff0c;虚拟化使得在一台物理的服务器上可以跑多台虚拟机&#xff0c;虚拟机共享物理机的 CPU、内存、IO 硬件资源&#xff0c;但逻辑上虚拟机之间是相互隔离的。 物理机我们一般称为宿主机&#xff08;Host&…

arm 外部中断

main.c: #include"key_inc.h" //封装延时函数 void delay(int ms) {int i,j;for(i0;i<ms;i){for(j0;j<2000;j){}} } int main() {//按键中断的初始化key1_it_config();key2_it_config();key3_it_config();while(1){printf("in main pro\n");delay(1…

(人才测评)自媒体运营的招聘入职测评方案

互联网如今发展的如此之快&#xff0c;各种信息爆炸&#xff0c;各种手机游戏量产的时代&#xff0c;除此之外还有一些新兴的岗位诞生&#xff0c;那就是自媒体行业&#xff0c;可以说有了互联网&#xff0c;只要你想做&#xff0c;一个人也可以在网络上发布有趣搞笑的视频&…

WPF使用外部字体,思源黑体,为例子

1.在工程中新建文件夹&#xff0c;命名为“Font"。 2.将下载好的字体文件复制到Font文件夹。 3.在工程中&#xff0c;加入静态资源 <Window.Resources><FontFamily x:Key"SYBold">/AnalyzeImage;Component/Font/#思源黑体 CN Bold</FontFamily…

Ecmascript 和javascript的区别

ECMAScript 是什么&#xff1f; 想象一下&#xff0c;ECMAScript&#xff08;简称ES&#xff09;是个“剧本”&#xff0c;规定了“舞台剧”的基本表演规则和动作。在这个比喻中&#xff0c;“舞台剧”就是我们常说的JavaScript。ECMAScript是由欧洲计算机制造商协会&#xff0…

【保姆级教程】YOLOv8_Cls图像分类:训练自己的数据集

一、YOLOV8环境准备 1.1 下载安装最新的YOLOv8代码 仓库地址&#xff1a; https://github.com/ultralytics/ultralytics1.2 配置环境 pip install -r requirements.txt -i https://pypi.tuna.tsinghua.edu.cn/simple二、数据准备 我这里准备了猫和狗的图片&#xff0c;按类别…

学习周报:文献阅读+Fluent案例+水力学理论学习

目录 摘要 Abstract 文献阅读&#xff1a; 文献摘要 现有问题 研究目的及方法 PINN的设置 NS方程介绍 损失函数 训练方法 实验设置 对照组设置 实验结果展示 点云数、隐藏层数和每个隐藏层的节点数对PINN精度的影响 点云数对PINN的影响&#xff1a; 隐藏层数的影…

喜欢我中文编程吗?这么喜欢中文编程哥们给你来点关键字呗

// chinese_commands.h 太优雅了哥们// 变量类型 #define 整型 int #define 浮点型 float #define 双浮点型 double #define 字符 char #define 长整型 long #define 自动 auto #define 布尔 bool// 修饰符 #define 静态 static #define 常量 const #define 虚拟 virtual #defi…

吴恩达深度学习笔记:神经网络的编程基础2.1-2.4

目录 第一门课&#xff1a;神经网络和深度学习 (Neural Networks and Deep Learning)第二周&#xff1a;神经网络的编程基础 (Basics of Neural Network programming)2.1 二分类(Binary Classification)2.2 逻辑回归(Logistic Regression)2.3 逻辑回归的代价函数&#xff08;Lo…

C++基础之继承(十五)

一.继承的定义 当一个派生类继承一个基类时&#xff0c;需要在派生类的类派生列表中明确的指出它是从哪个基类继承而来的。类派生列表的形式如下&#xff1a; class 派生类 : public/private/protected 基类 { }&#xff1b; 派生类生成的三个步骤&#xff1a; 吸收基类成员…

如何恢复回收站被清空的文件?3个宝藏方法大公开!

“怎么办&#xff1f;不小心把回收站里的文件都清空了&#xff0c;现在没法找回我的重要数据了&#xff0c;有什么比较好的方法吗&#xff1f;快来帮帮我吧&#xff01;” 回收站作为Windows系统中的一个重要功能&#xff0c;可以帮助我们暂时存放删除的文件和文件夹&#xff0…

数据结构——树与二叉树

目录 树与二叉树 1.树的定义 2.树的有关术语 3.二叉树&#xff08;BinaryTree&#xff09; 二叉树的性质&#xff1a; 特殊的二叉树 满二叉树&#xff1a; 完全二叉树 二叉树的存储结构 顺序存储结构 链式存储结构 二叉树以及对应接口的实现 1.二叉树架构搭建 2…

PSO-CNN-BiLSTM多输入分类预测|粒子群优化算法-卷积-双向长短期神经网络分类预测|Matlab

目录 一、程序及算法内容介绍&#xff1a; 基本内容&#xff1a; 亮点与优势&#xff1a; 二、实际运行效果&#xff1a; 三、算法介绍&#xff1a; 四、完整程序下载&#xff1a; 一、程序及算法内容介绍&#xff1a; 基本内容&#xff1a; 本代码基于Matlab平台编译&am…

【Python机器学习系列】机器学习中的模型微调---随机搜索(案例+源码)

这是我的第245篇原创文章。 一、引言 如果探索的组合数量较少时&#xff0c;网格搜索是一种不错的方法&#xff0c;但当超参数的搜索范围较大时&#xff0c;通常会优先选择使用 RandomizedSearchCV 。它与 GridSearchCV 用法相似&#xff0c;但它不会尝试所有可能的组合&…

智能医疗-行业痛点

信息来源渠道少 病患只能从特定时间巡房的医护处了解病情&#xff0c;信息来源渠道少&#xff0c;了解信息内容有限。 床头卡老旧&#xff0c;信息更新不及时 每位医护人员负责的床铺数量多&#xff0c;床头卡更新频率快&#xff0c;替换纸质床头卡需打印、手写、张贴等一系列…

发展规划--IM系统

1、时代背景 5G应用&#xff0c;多终端应用&#xff0c;物联网应用&#xff0c;小程序&#xff0c;工业互联&#xff0c;大数据应用等等大前端时代的到来&#xff0c;程序员不能只关注crud&#xff0c;因为以后的服务并发量只会越来越多。 高并发架构师、大数据架构师或者说j…

ABC346 A-G 题解

ABC346 A-G题解 A题目AC Code&#xff1a;时间复杂度 B题目时间复杂度AC Code&#xff1a; C题目时间复杂度AC Code&#xff1a; D题目时间复杂度AC Code&#xff1a; E题目时间复杂度AC Code&#xff1a; F题目时间复杂度AC Code&#xff1a; G题目时间复杂度AC Code&#xff…

关于四篇GNN论文的阅读笔记PPT:包括GATNE,AM-GCN,HGSL和coGSL

关于四篇GNN论文的阅读笔记PPT&#xff1a;包括GATNE&#xff0c;AM-GCN&#xff0c;HGSL和coGSL 前言GATNEAM-GCNHGSLcoGSL 前言 这里的PPT主要是在跟Graph Transformer一起的&#xff1a; 【图-注意力笔记&#xff0c;篇章1】Graph Transformer&#xff1a;包括Graph Trans…

LeetCode每日一题——移除链表元素

移除链表元素OJ链接&#xff1a;203. 移除链表元素 - 力扣&#xff08;LeetCode&#xff09; 题目&#xff1a; 思路&#xff1a; 这与之前的移除元素的题目很相似&#xff0c;那么我们同样可以用类似的做法&#xff08;双指针&#xff09;进行解题。但是这是一个链表删除&a…