腐烂的橘子

腐烂的橘子

读完题目感觉也就是个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;
    }
};

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

相关推荐
CoderCodingNo38 分钟前
【GESP】C++五级练习题 luogu-P1865 A % B Problem
开发语言·c++·算法
大闲在人1 小时前
7. 供应链与制造过程术语:“周期时间”
算法·供应链管理·智能制造·工业工程
小熳芋1 小时前
443. 压缩字符串-python-双指针
算法
Charlie_lll1 小时前
力扣解题-移动零
后端·算法·leetcode
chaser&upper1 小时前
矩阵革命:在 AtomGit 解码 CANN ops-nn 如何构建 AIGC 的“线性基石”
程序人生·算法
weixin_499771551 小时前
C++中的组合模式
开发语言·c++·算法
iAkuya2 小时前
(leetcode)力扣100 62N皇后问题 (普通回溯(使用set存储),位运算回溯)
算法·leetcode·职场和发展
近津薪荼2 小时前
dfs专题5——(二叉搜索树中第 K 小的元素)
c++·学习·算法·深度优先
xiaoye-duck2 小时前
吃透 C++ STL list:从基础使用到特性对比,解锁链表容器高效用法
c++·算法·stl
松☆2 小时前
CANN与大模型推理:在边缘端高效运行7B参数语言模型的实践指南
人工智能·算法·语言模型