leetcode 994.腐烂的橘子

题目:

在给定的网格中,每个单元格可以有以下三个值之一:

  • 值 0 代表空单元格;
  • 值 1 代表新鲜橘子;
  • 值 2 代表腐烂的橘子。

每分钟,任何与腐烂的橘子(在 4 个正方向上)相邻的新鲜橘子都会腐烂。

返回直到单元格中没有新鲜橘子为止所必须经过的最小分钟数。如果不可能,返回 -1

 

分析:

最近在看广度优先搜素的题目,这个是比较简单基础的题了。

腐烂的橘子会把靠近他的新鲜的橘子腐蚀,那么就是只要从所有坏的橘子的地方一层一层往外遍历就可以了。

代码:

 1 //5ms 97%
 2 class Solution {
 3     public int orangesRotting(int[][] grid) {
 4         Queue<int[]> q=new LinkedList<>();
 5         int h=grid.length,w=grid[0].length,time=0;
 6         for(int n=0;n<h;++n)
 7             for(int m=0;m<w;++m)
 8                 if(grid[n][m]==2) {
 9                     int[] po= {0,n,m};
10                     q.add(po);
11                 }
12         while(!q.isEmpty()) {
13             int[] g=q.poll();
14             time=time>g[0]?time:g[0];
15             if(g[1]+1<h&&grid[g[1]+1][g[2]]==1) {
16                 grid[g[1]+1][g[2]]=2;
17                 int[] po= {g[0]+1,g[1]+1,g[2]};
18                 q.add(po);            
19             }
20             if(g[1]-1>=0&&grid[g[1]-1][g[2]]==1) {
21                 grid[g[1]-1][g[2]]=2;
22                 int[] po= {g[0]+1,g[1]-1,g[2]};
23                 q.add(po);            
24             }
25             if(g[2]-1>=0&&grid[g[1]][g[2]-1]==1) {
26                 grid[g[1]][g[2]-1]=2;
27                 int[] po= {g[0]+1,g[1],g[2]-1};
28                 q.add(po);            
29             }
30             if(g[2]+1<w&&grid[g[1]][g[2]+1]==1) {
31                 grid[g[1]][g[2]+1]=2;
32                 int[] po= {g[0]+1,g[1],g[2]+1};
33                 q.add(po);            
34             }
35         }
36         for(int n=0;n<h;++n)
37             for(int m=0;m<w;++m)
38                 if(grid[n][m]==1) 
39                     return -1;
40         return time;
41     }
42 }

 

转载于:https://www.cnblogs.com/CHAHA123/p/10736353.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/350782.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

运行时异常和检查性异常区别

Java提供了两类主要的异常:runtime exception和checked exception。checked 异常也就是我们经常遇到的IO异常&#xff0c;以及SQL异常都是这种异常。对于这种异常&#xff0c;JAVA编译器强制要求我们必需对出现的这些异常进行catch。所以&#xff0c;面对这种异常不管我们是否愿…

VS2015配置freegult

与vs配置opencv类似 1.首先先找到自己系统里OpenGL相关.h.lib .dll的位置 一般系统里已自带&#xff0c;只要去找到就好&#xff0c;我的位置&#xff1a; gl.h C:\Program Files\Microsoft SDKs\Windows\v6.0A\Include\gl OpenGL32.Lib GlU32.Lib C:\Program Files\Microsoft…

java 死锁的检测与修复_调查死锁–第4部分:修复代码

java 死锁的检测与修复在这个简短的博客系列的最后BadTransferOperation中&#xff0c;我一直在讨论分析死锁&#xff0c;我将修复BadTransferOperation代码。 如果您已经看过本系列的其他博客 &#xff0c;那么您会知道&#xff0c;为了达到这一点&#xff0c;我创建了死锁演示…

python下载url_三种Python下载url并保存文件的代码详解

利用程序自己编写下载文件挺有意思的。 Python中最流行的方法就是通过Http利用urllib或者urllib2模块。 当然你也可以利用ftplib从ftp站点下载文件。此外Python还提供了另外一种方法requests。 来看看三种方法是如何来下载zip文件的&#xff1a; import urllib import urllib2 …

springcloud(七)-Feign声明式REST调用

前言 前面我们使用的RestTemplate实现REST API调用&#xff0c;代码大致如下&#xff1a; public User findById(PathVariable Long id) {return restTemplate.getForObject("http://localhost:8084/" id, User.class);} 由代码可知&#xff0c;我们是使用拼接字符串…

OpenGL 各类库的解析gl glu glut freeglut glfw glew

gl.h gl库是核心库&#xff0c;gl中包含了最基本的3D函数&#xff0c;可以再本地电脑中的&#xff1a; C:\Program Files (x86)\MicrosoftSDKs\Windows\v7.0A\Include\gl 路径下找到gl.h头文件&#xff0c;打开后可以看到其中定义的上百个相关函数。 glu.h glu是实用库&#xf…

Java中throw和throws的区别

系统自动抛出的异常 所有系统定义的编译和运行异常都可以由系统自动抛出&#xff0c;称为标准异常&#xff0c;并且 Java 强烈地要求应用程序进行完整的异常处理&#xff0c;给用户友好的提示&#xff0c;或者修正后使程序继续执行。 语句抛出的异常 用户程序自定义的异常和应…

面试问题:检查牙套

这是较容易的编码任务之一&#xff0c;但是您仍然可以在一些初步的技术筛选中达到要求。 问题看起来像这样&#xff1a; 给定仅包含字符( &#xff0c; ) &#xff0c; { &#xff0c; } &#xff0c; [和]的字符串&#xff0c;请确定输入字符串是否有效。 括号必须以正确的顺…

python字符串长度_如何使用python获取字符串长度?哪些方法?

掌握多种python技巧&#xff0c;对于我们更好的灵活应用python是非常重要的&#xff0c;比如接下来给大家介绍的获取字节长度&#xff0c;那大家脑海里就该有印象了&#xff0c;有几种方法呢&#xff1f;一起来看下吧~1、使用len&#xff08;&#xff09;函数 这是最直接的方法…

C++内存

在C中&#xff0c;内存分成5个区&#xff0c;他们分别是堆、栈、自由存储区、全局/静态存储区和常量存储区。 栈&#xff0c;就是那些由编译器在需要的时候分配&#xff0c;在不需要的时候自动清楚的变量的存储区。里面的变量通常是局部变量、函数参数等。 堆&#xff0c;就是那…

Dijkstra算法——计算一个点到其他所有点的最短路径的算法

迪杰斯特拉算法百度百科定义&#xff1a;传送门 gh大佬博客&#xff1a;传送门 迪杰斯特拉算法用来计算一个点到其他所有点的最短路径&#xff0c;是一种时间复杂度相对比较优秀的算法 O&#xff08;n2&#xff09;&#xff08;相对于Floyd算法来说&#xff09; 是一种单源最短…

浅谈java中extends与implements的区别

Extends可以理解为全盘继承了父类的功能。implements可以理解为为这个类附加一些额外的功能&#xff1b;interface定义一些方法,并没有实现,需要implements来实现才可用。extend可以继承一个接口,但仍是一个接口,也需要implements之后才可用。对于class而言&#xff0c;Extends…

注意力机制 神经网络_图注意力网络(GAT)

引言作者借鉴图神经网络中的注意力机制&#xff0c;提出了图注意力神经网络架构&#xff0c;创新点主要包含如下几个&#xff1a;①采用masked self-attention层&#xff0c;②隐式的对邻居节点采用不同权重③介绍了多头注意力机制。 在作者的Introduction中&#xff0c;该论文…

java版问题

1.必填项在初次保存后应该已经有值了&#xff0c;怎么会加载数据又是空的的&#xff1f; 2.客户类型 企业性质&#xff1f; 一般机构、上市公司.... 3.文档管理-->上传文档&#xff0c;如果左侧选中文档节点时&#xff0c;上传文档时是否默认选中文档节点。 转载于:https:/…

html5标签属性大全_HTML5中video标签如何使用

HTML5中的video标签用于播放视频文件的&#xff0c;在video标签中我们可以设置窗口的宽高&#xff0c;视频的自动播放&#xff0c;循环播放以及视频的封面图片等等HTML5是下一代HTML&#xff0c;新增了许多新的标签&#xff0c;这些标签实现了许多新的功能。并且还减少了对外部…

Java中@Override的作用

Override是伪代码,表示重写(当然不写也可以)&#xff0c;不过写上有如下好处: 1、可以当注释用,方便阅读&#xff1b; 2、编译器可以给你验证Override下面的方法名是否是你父类中所有的&#xff0c;如果没有则报错。例如&#xff0c;你如果没写Override&#xff0c;而你下面的…

java程序中用户名和密码_在Java应用程序中使用密码术

java程序中用户名和密码这篇文章描述了如何使用Java密码体系结构 &#xff08;JCA&#xff09;&#xff0c;该体系结构使您可以在应用程序中使用密码服务。 Java密码体系结构服务 JCA提供了许多加密服务&#xff0c;例如消息摘要和签名 。 这些服务可通过特定于服务的API来访…

C++ setw和setfill

在C中&#xff0c;setw(int n)用来控制输出间隔。 例如: cout<<s<<setw(8)<<a<<endl; 则在屏幕显示 s a //s与a之间有7个空格&#xff0c;setw()只对其后面紧跟的输出产生作用&#xff0c;如上例中&#xff0c;表示a共占8个位置&#xff0c;不…

Linux快捷键

附上一些其他较长使用的快捷键&#xff1a; ctrl w —往回删除一个单词&#xff0c;光标放在最末尾 ctrl k —往前删除到末尾&#xff0c;光标放在最前面&#xff08;可以使用ctrla&#xff09; ctrl u 删除光标以前的字符 ctrl k 删除光标以后的字符 ctrl a 移动光标至的…

会python基础可以找到工作吗_我大学退学,现在 28 岁,如果零基础开始学 python,可以找到工作吗?...

作为一名IT行业从业者&#xff0c;同时也是一名教育工作者&#xff0c;我来回答一下这个问题。 首先&#xff0c;对于28岁且没有获得大学文凭的初学者来说&#xff0c;要想通过学习Python来找到工作还是具有一定难度的&#xff0c;一方面原因是目前开发岗位通常都有一定的学历要…