【LeetCode994】腐烂的橘子(C++)

题目传送门:994. 腐烂的橘子 - 力扣(LeetCode)

题解

题目大意为给定一张m×n的网格,每个格中可能是新鲜橘子,腐烂橘子或者空,腐烂橘子每分钟会使其上下左右的四个位置的新鲜橘子腐烂,求多少分钟后格子中没有新鲜橘子。

根据腐烂橘子扩散的特性与广度优先搜索的方法相同,本文将使用广搜完成。

首先对网格进行预处理,分别将好橘子和烂橘子的坐标记录到两个队列que中,此处用数组模拟队列,在记录是还使用到了一个小技巧,如果同时记录行列信息需要两个变量,根据数据范围行列都小于等于10,所以我们将行列拼成一个四位数,例如3行5列记录为0305=3*100+5,10行1列记为1001=10*100+1。

接下来我们开始模拟腐烂扩散的过程,其中timee[i]记录队列中第i个橘子是第几分钟腐烂的。采用广搜的方法,每次从烂橘子队列的队头提取烂橘子坐标,然后分别看它的上下左右四个方向是否为好橘子,如果是则将其传染为烂橘子,并添加到烂橘子队列的队尾,同时其腐烂时间为队头橘子腐烂时间的下一分钟。按照上面的过程直到所有的烂橘子都扩散完成。

接下来的check部分,检查之前记录的好橘子队列,如果其中还存在新鲜橘子,返回-1。否则在好橘子队列检查完后,返回最后一个橘子被腐烂的时间,即经过多少分钟格子中没有新鲜橘子。

参考代码

class Solution {
public:
    int orangesRotting(vector<vector<int>>& grid) {
        int m = grid.size();
        int n = grid[0].size();
        int badque[105],badl=0,goodque[105],goodl=0,hang,lie,tim
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值