腐烂的橘子

腐烂的橘子

读完题目感觉也就是个bfs的题。好吧 今天咳嗽咳到睡不着 直接起来做题了。。

思路:直接把最开始所有的腐烂的位置加入队列,然后bfs的时候每次取出的是腐烂的所有当前层橘子,

思路感觉一直都很清晰,就是代码挺复杂的还。

直接写代码吧:

cpp 复制代码
class Solution {
    typedef pair<int,int> PII;
    queue<PII>q;
    int dx[4]={0,0,-1,1},dy[4]={1,-1,0,0};
public:
    int orangesRotting(vector<vector<int>>& grid) {
        int ans=0;//所需分钟数
        int n=grid.size();
        int m=grid[0].size();
        int xxjz=0;//新鲜橘子个数
        for(int i=0;i<n;i++)
        {
            for(int j=0;j<m;j++)
            {
                if(grid[i][j]==2)
                {
                    q.push({i,j});
                }
                else if(grid[i][j]==1)
                {
                    xxjz++;
                }
            }
        }
        if(xxjz==0) return 0;//一开始就没有新鲜橘子
        if(q.empty()) return -1;//没有腐烂的橘子但是有新鲜的橘子,故不可能
        while(!q.empty())
        {
            int sz=q.size();
            while(sz>0)
            {
                auto t=q.front();
                q.pop();
                sz--;
                int x=t.first;
                int y=t.second;
                for(int i=0;i<4;i++)
                {
                    int nx=x+dx[i];
                    int ny=y+dy[i];
                    if(nx>=0&&nx<grid.size()&&ny>=0&&ny<grid[0].size()&&grid[nx][ny]==1)
                    {
                        q.push({nx,ny});
                        grid[nx][ny]=2;
                        xxjz--;
                    }
                }
            }
            ans++;  //这样写 ans 每次循环都会增加,即使这一轮并没有腐烂新的橘子。这个问题会导致最终返回的结果比实际所需的时间多1。
        }
        if(xxjz!=0) return -1;
        return ans-1;
    }
};

感觉自己写这一块已经有点那个意思了,嘻嘻。

相关推荐
程序员莫小特5 小时前
老题新解|大整数加法
数据结构·c++·算法
过往入尘土6 小时前
服务端与客户端的简单链接
人工智能·python·算法·pycharm·大模型
zycoder.6 小时前
力扣面试经典150题day1第一题(lc88),第二题(lc27)
算法·leetcode·面试
蒙奇D索大6 小时前
【数据结构】考研数据结构核心考点:二叉排序树(BST)全方位详解与代码实现
数据结构·笔记·学习·考研·算法·改行学it
智驱力人工智能7 小时前
工厂抽烟检测系统 智能化安全管控新方案 加油站吸烟检测技术 吸烟行为智能监测
人工智能·算法·安全·边缘计算·抽烟检测算法·工厂抽烟检测系统·吸烟监测
程序员爱钓鱼7 小时前
Go语言实战案例——进阶与部署篇:编写Makefile自动构建Go项目
后端·算法·go
_Power_Y8 小时前
Java面试常用算法api速刷
java·算法·面试
艾醒(AiXing-w)8 小时前
大模型面试题剖析:模型微调中冷启动与热启动的概念、阶段与实例解析
人工智能·深度学习·算法·语言模型·自然语言处理
天选之女wow8 小时前
【代码随想录算法训练营——Day32】动态规划——509.斐波那契数、70.爬楼梯、746.使用最小花费爬楼梯
算法·leetcode·动态规划
红衣小蛇妖8 小时前
LeetCode-704-二分查找
java·算法·leetcode·职场和发展