鱼C论坛

 找回密码
 立即注册
查看: 2143|回复: 0

[技术交流] LeetCode 994. 腐烂的橘子

[复制链接]
发表于 2020-3-4 12:49:57 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
本帖最后由 798236606 于 2020-3-5 10:12 编辑

传送门:https://leetcode-cn.com/problems/rotting-oranges/

BFS
  1. class Solution {
  2. public:
  3.     struct Pos{
  4.         int x, y;
  5.     };

  6.     int good = 0;
  7.     bool vis[15][15] = {false};
  8.     queue<Pos> q;

  9.     void turn_bad(int x, int y)
  10.     {
  11.         q.push({x, y});
  12.         vis[x][y] = true;   
  13.         --good;   
  14.     }

  15.     int orangesRotting(vector<vector<int>>& grid) {


  16.         int r = grid.size(), c = grid[0].size();


  17.         for (int i = 0; i < r; ++i)
  18.         {
  19.             for (int j = 0; j < c; ++j)
  20.             {
  21.                 if (grid[i][j] == 2)
  22.                 {
  23.                     q.push({i, j});
  24.                     vis[i][j] = true;
  25.                 }

  26.                 if (grid[i][j] == 1) ++good;         
  27.             }
  28.         }

  29.         if (!good) return 0;

  30.         int t = 0;
  31.         while (int k = q.size())
  32.         {
  33.             if (!good) return t;

  34.             while (k--)
  35.             {
  36.                 Pos p = q.front();
  37.                 q.pop();

  38.                 if (p.x > 0     && !vis[p.x - 1][p.y] && grid[p.x - 1][p.y] == 1) turn_bad(p.x - 1, p.y);
  39.                 if (p.x < r - 1 && !vis[p.x + 1][p.y] && grid[p.x + 1][p.y] == 1) turn_bad(p.x + 1, p.y);
  40.                 if (p.y > 0     && !vis[p.x][p.y - 1] && grid[p.x][p.y - 1] == 1) turn_bad(p.x, p.y - 1);
  41.                 if (p.y < c - 1 && !vis[p.x][p.y + 1] && grid[p.x][p.y + 1] == 1) turn_bad(p.x, p.y + 1);
  42.             }

  43.             ++t;
  44.         }      

  45.         return -1;
  46.     }
  47. };
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2025-7-6 16:31

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表