当前位置: 首页 > article >正文

每日OJ题_牛客_ 腐烂的苹果_多源BFS_C++_Java

目录

牛客_腐烂的苹果(多源 BFS)

题目解析

C++代码

Java代码


牛客_腐烂的苹果(多源 BFS)

腐烂的苹果_牛客题霸_牛客网


题目解析

多源 BFS 问题,固定套路,BFS学习 :Offer必备算法28_多源BFS_四道力扣题详解(由易到难)_bfs算法题力扣-CSDN博客

C++代码

class Solution
{
    int m = 0, n = 0;
    int dx[4] = {0, 0, 1, -1};
    int dy[4] = {1, -1, 0, 0};
    bool vis[1010][1010] = { 0 };
    public:
    int rotApple(vector<vector<int> >& grid)
    {
        m = grid.size(), n = grid[0].size();
        queue<pair<int, int>> q;
        for(int i = 0; i < m; i++)
            for(int j = 0; j < n; j++)
                if(grid[i][j] == 2)
                    q.push({i, j});

        int ret = 0;
        while(q.size())
        {
            int sz = q.size();
            ret++;
            while(sz--)
            {
                auto [a, b] = q.front();
                q.pop();
                for(int i = 0; i < 4; i++)
                {
                    int x = a + dx[i], y = b + dy[i];
                    if(x >= 0 && x < m && y >= 0 && y < n && grid[x][y] == 1
                       && !vis[x][y])
                    {
                        vis[x][y] = true;
                        q.push({x, y});
                    }
                }
            }
        }
        for(int i = 0; i < m; i++)
            for(int j = 0; j < n; j++)
                if(grid[i][j] == 1 && !vis[i][j])
                    return -1;

        return ret - 1;
    }
};

Java代码

import java.util.*;
public class Solution
{
    int[] dx = {0, 0, 1, -1};
    int[] dy = {1, -1, 0, 0};
    public int rotApple (ArrayList<ArrayList<Integer>> grid)
    {
        int m = grid.size();
        int n = grid.get(0).size();
        boolean[][] vis = new boolean[m][n];
        Queue<int[]> q = new LinkedList<>();
        for(int i = 0; i < m; i++)
        {
            for(int j = 0; j < n; j++)
            {
                if(grid.get(i).get(j) == 2)
                {
                    q.add(new int[]{i, j});
                }
            }
        }
        int ret = 0;
        while(!q.isEmpty())
        {
            int sz = q.size();
            while(sz-- != 0)
            {
                int[] t = q.poll();
                int a = t[0], b = t[1];
                for(int i = 0; i < 4; i++)
                {
                    int x = a + dx[i], y = b + dy[i];
                    if(x >= 0 && x < m && y >= 0 && y < n && vis[x][y] == false
                       && grid.get(x).get(y) == 1)
                    {
                        vis[x][y] = true;
                        q.add(new int[]{x, y});
                    }
                }
            }
            ret++;
        }
        // 判断剩余的苹果
        for(int i = 0; i < m; i++)
        {
            for(int j = 0; j < n; j++)
            {
                if(grid.get(i).get(j) == 1 && !vis[i][j])
                {
                    return -1;
                }
            }
        }
        return ret - 1;
    }
}

http://www.kler.cn/a/319942.html

相关文章:

  • VS Code--常用的插件
  • Dart语言的语法
  • 【经济学通识——国债】
  • 基于微信小程序的摄影竞赛系统设计与实现(LW+源码+讲解)
  • STM32网络通讯之CubeMX实现LWIP项目设计(十五)
  • Ondo SIP Server
  • 线性判别分析 (LDA)中目标函数两个相似公式 分子 之间的转换过程
  • AUTOSAR汽车电子嵌入式编程精讲300篇-基于CAN总线的气动控制(中)
  • 用 Django 5 快速生成一个简单 进销存 系统 添加 个打印 按钮
  • 10-pg内核之锁管理器(五)行锁
  • python划分CSV格式的数据集
  • 基于Jeecg-boot开发系统--后端篇
  • OpenHarmony(鸿蒙南向)——平台驱动开发【PIN】
  • Linux系统安装和配置 VNC 服务器
  • C语言 | Leetcode C语言题解之第423题从英文中重建数字
  • Trapezoidal Decomposition梯形分解算法(TCD)
  • 【Linux实践】实验四:Shell实用功能及文件权限
  • PHP API 框架:构建高效API的利器
  • spark读取数据性能提升
  • PostgreSQL技术内幕12:PostgreSQL事务原理解析-锁管理
  • 【Axure视频教程】跨页面控制中继器表格
  • 商城小程序后端开发实践中出现的问题及其解决方法
  • 【算法——双指针】
  • 机器学习中的KNN算法:原理、应用与实践
  • xpath在爬虫中的应用、xpath插件的安装及使用
  • Python爬虫-Post请求中,参数只有value没有key,如何正确处理?