java数据结构与算法刷题-----LeetCode695. 岛屿的最大面积

news2024/11/28 20:47:58
java数据结构与算法刷题目录(剑指Offer、LeetCode、ACM)-----主目录-----持续更新(进不去说明我没写完):https://blog.csdn.net/grd_java/article/details/123063846

文章目录

    • 1. 深度优先遍历
    • 2. 广度优先

在这里插入图片描述

1. 深度优先遍历

这不是找最短路径,而是找面积,所以深度优先更适合。

解题思路:时间复杂度O( r ∗ c r*c rc)r和c表示行列个数,也就是整张二维地图都遍历一边,空间复杂度O( r ∗ c r*c rc)
  1. 一行一行的遍历地图,如果发现当前结点 = 1表示陆地,就从当前坐标开始进行深度优先遍历
  2. 遍历过的结点将其标记为已访问,然后朝向上下左右四个方向依次继续深度优先遍历,并将结果相加。
代码

在这里插入图片描述

class Solution {
    public int maxAreaOfIsland(int[][] grid) {
        int max = 0;//保存答案
        for (int r = 0; r < grid.length; r++) {
            for (int c = 0; c < grid[0].length; c++) {//遍历地图
                if(grid[r][c]==1){//如果是陆地,就进入深度优先遍历,统计其陆地大小
                    int res = dfs(grid,r,c);//dfs
                    max = Math.max(max,res);//如果当前陆地更大,就保存其为答案
                }
            }
        }
        return max;//返回最大陆地大小
    }
    //深度优先遍历
    int dfs(int[][] grid,int r,int c){
        int m = grid.length,n = grid[0].length;//地图边界
        if(r<0||c<0||r>=m||c>=n) return 0;//如果当前坐标不在地图中,返回0,表示当前坐标陆地面积为0

        if(grid[r][c]!=1) return 0;//如果当前坐标在地图中,但是是海洋(0)或者已经统计过的陆地(2)的话,也返回0表示当前坐标陆地面积为0
        grid[r][c]=2;//如果当前坐标是陆地,将其置为2,表示已经访问过
        //然后从当前坐标向4个方向走一步继续统计。
        return 1+dfs(grid,r-1,c)+dfs(grid,r+1,c)+dfs(grid,r,c-1)+dfs(grid,r,c+1);
    }

}

2. 广度优先

这题不太适合广度优先,代码会比较多,没有深度优先遍历简洁,并且需要使用Java自带容器Queue,会比深度优先遍历的底层栈空间慢很多

解题思路:时间复杂度O( r ∗ c r*c rc),空间复杂度O( r ∗ c r*c rc)
  1. 和法一深度优先遍历一样,就是将代码转换为广度优先而已
代码

在这里插入图片描述

class Solution {
    int[][] grid;//保存地图
    int m,n;//地图边界
    final int[][] directions = new int[][]{{-1, 0}, {1, 0}, {0, 1}, {0, -1}};//方向参数,上下右左
    public int maxAreaOfIsland(int[][] grid) {
        this.grid = grid;
        this.m = grid.length; this.n = grid[0].length;//获取边界
        int result = Integer.MIN_VALUE;//保存最终结果
        for(int i = 0; i < m; i++){
            for(int j = 0; j < n; j++){
                if(grid[i][j] == 1){
                    int size = bfs(i, j);
                    result = Math.max(size, result);
                }
            }
        }
        return result == Integer.MIN_VALUE ? 0 : result;
    }
    private int bfs(int x, int y){
        int area = 1;//当前坐标陆地面积
        Queue<int[]> queue = new ArrayDeque<>();//广度优先遍历
        queue.offer(new int[]{x, y});//当前坐标入队列
        grid[x][y] = 2;//将其标志为2,表示已经访问
        while(!queue.isEmpty()){//广度优先遍历
            int[] current = queue.poll();//出队列当前坐标
            for(int[] dir : directions){//4个方向各走一步
                //获取当前方向走一步后的坐标
                int nextX = current[0] + dir[0];
                int nextY = current[1] + dir[1];
                //如果下标没有越界,并且 = 1确定是陆地,就将其加入队列中
                if(nextX >= 0 && nextX < grid.length && nextY >= 0 && nextY < grid[0].length && grid[nextX][nextY] == 1){
                    area++;//走一步,面积+1
                    queue.offer(new int[]{nextX, nextY});//入队列
                    grid[nextX][nextY] = 2;//标识为2,表示已经统计
                }
            }
        }
        return area;
    }
}

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

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

相关文章

量化交易入门(三十八)CCI指标Python实现和回测

今天我们先单纯用CCI指标来完成策略的编写&#xff0c;后续我们会改进这个策略&#xff0c;将CCI指标和前面讲到的MACD和RSI相结合来优化&#xff0c;看看我们优化后的效果会不会更好。 一、量化策略 CCI指标在量化交易中的策略&#xff1a; 在以下情况下生成买入信号&#…

C# 排序的多种实现方式(经典)

一、 对数组进行排序 最常见的排序是对一个数组排序&#xff0c;比如&#xff1a; int[] aArray new int[8] { 18, 17, 21, 23, 11, 31, 27, 38 }; 1、利用冒泡排序进行排序&#xff1a; &#xff08;即每个值都和它后面的数值比较&#xff0c;每次拿出最小值&#xff09; s…

黄仁勋:我们有望在未来五到十年内见证完全由人工智能生成的游戏

黄仁勋&#xff1a;我们有望在未来五到十年内见证完全由人工智能生成的游戏 近日&#xff0c;英伟达&#xff08;Nvidia&#xff09;GPU技术大会上&#xff0c;英伟达首席执行官黄仁勋&#xff08;Jensen Huang&#xff09;对未来游戏产业的展望引发了业界的广泛关注。在一次与…

centos安装docker,docker安装centos进而安装宝塔

背景 由于工作需要自己有许多的web应用要部署在云服务器上。然而资金有限每年都要去阿里云&#xff0c;腾讯云&#xff0c;华为云买最便宜的服务器&#xff0c;这就意味着每年都要经历一次痛苦的环境安装项目部署的过程&#xff08;nginx、mysql、elasticsearch、redis等等&am…

【Redis】Redis的类型及相关操作

一、常用的key操作命令 keys * 查看当前数据库的键值 ttl key 查看还有多少秒过期&#xff0c;-1表示永不过期&#xff0c;-2表示过期 del / unlink key 同样是删除&#xff0c;unlink是非阻塞删除&#xff0c;del则有可能导致阻塞 select dbindex 切换数据库 flushdb 清空…

CA根证书——https安全保障的基石

HTTPS通信中&#xff0c;服务器端使用数字证书来证明自己的身份。客户端需要验证服务器发送的证书的真实性。这就需要一个可信的第三方机构&#xff0c;即CA&#xff0c;来颁发和管理证书。CA根证书是证书颁发机构层次结构的顶级证书&#xff0c;客户端信任的所有证书都可以追溯…

并发编程之线程池的详细解析

线程池 线程池的优势&#xff1a; 线程池做的工作只要是控制运行的线程数量&#xff0c;处理过程中将任务放入队列&#xff0c;然后线程创建石后启动这些任务&#xff0c;如果线程数量超过了最大数量&#xff0c;超出数量的线程排队等候&#xff0c;等其他线程执行完毕&#xf…

【回眸】Tessy 单元测试软件使用指南(三)怎么打桩和指针赋值和测试

目录 前言 Tessy 如何进行打桩操作 普通桩 高级桩 手写桩 Tessy单元测试之指针相关测试注意事项 有类型的指针&#xff08;非函数指针&#xff09;&#xff1a; 有类型的函数指针&#xff1a; void 类型的指针&#xff1a; 结语 前言 进行单元测试之后&#xff0c;但凡…

css-盒子阴影

1.box-shadow: 10px 20px 10px 10px blue; 参数对应顺序&#xff1a;上下&#xff0c;左右 &#xff0c;模糊程度&#xff0c;颜色 &#xff0c;阴影大小 2.box-shadow: 10px 20px 10px 20px blue,-10px -20px 10px 50px red; 负号就是相反方向 支持多个阴影 在后面加逗号 3…

dockerfile制作-pytoch+深度学习环境版

你好你好&#xff01; 以下内容仅为当前认识&#xff0c;可能有不足之处&#xff0c;欢迎讨论&#xff01; 文章目录 文档内容docker相关术语docker常用命令容器常用命令根据dockerfile创建容器dokerfile文件内容 docker问题&#xff1a;可能的原因和解决方法示例修改修改后的D…

谷粒商城——通过接口幂等性防止重复提交订单

如果用户向后端服务提交多次相同订单的提交服务&#xff0c;那么后端应该只生成一条订单记录。 有一些操作天然是幂等的&#xff0c;如查询操作和删除操作等。 幂等性实现 1.token机制&#xff08;仅这个方法适用于订单的重复提交&#xff09; 后端先生成1个令牌将其记录在R…

MATLAB绘制堆叠填充图--巧用句柄

MATLAB绘制堆叠填充图–巧用句柄 目录 MATLAB绘制堆叠填充图--巧用句柄1. 主要原理讲解1.1 主要函数1.2 句柄原理 2. 绘图示例2.1 准备数据2.2 绘制堆叠填充图-使用句柄控制图形属性2.3 设置填充颜色和样式2.4 添加标题和标签2.5 绘图效果 3. 结语 堆叠填充图是一种常见的数据可…

【2024年5月备考新增】《2024高项论文精华版(3)考试技巧》

3 考试技巧 3.1 考试难度 考试难度上&#xff0c;越是常见的题目、越是被大家预测的题目&#xff0c;阅卷就会更严格。 越是大家猜测不到的&#xff0c;越是小众的题目&#xff0c;阅卷严格程度就会低。 3.2 技巧 1、记住软考论文的目的&#xff0c;不是为了证明你的格式严谨…

中科驭数超低时延网络解决方案入选2023年度金融信创优秀解决方案

近日&#xff0c;由中国人民银行领导、中国金融电子化集团有限公司牵头组建的金融信创生态实验室发布「2023年度第三期金融信创优秀解决方案」&#xff0c;中科驭数超低时延网络解决方案从众多方案中脱颖而出&#xff0c;成功入选&#xff0c;代表了该方案的技术创新和金融实践…

使用plasmo开发浏览器插件在网页指定位置添加自定义UI

使用plasmo开发浏览器插件的时候&#xff0c;有时候需要在指定网站的指定页面添加自定义的UI内容&#xff0c;如果通过content.js内容脚本去通过js创建的话&#xff0c;可就太麻烦了&#xff0c;要写不少的js代码。不过plasmo已经帮我们实现了这个功能&#xff0c;就是Content …

安全防御产品—锐安盾重磅上线,助力更安全、更流畅的业务体验

在互联网时代&#xff0c;互联网技术蓬勃发展&#xff0c;然而&#xff0c;随之而来的网络安全问题也备受关注。诸如DDoS攻击、CC攻击、常见Web攻击等攻击手段突如其来&#xff0c;导致企业业务中断&#xff0c;严重影响企业业务正常运行。对此&#xff0c;锐成云重磅推出安全防…

分布式全闪占比剧增 152%,2023 年企业存储市场报告发布

近日&#xff0c;IDC 发布了 2023 年度的中国存储市场报告。根据该报告&#xff0c;在 2023 年软件定义存储的市场占比进一步扩大&#xff0c;分布式全闪的增长尤其亮眼&#xff0c;其市场份额从 2022 年的 7% 剧增到 2023 年的 17.7%&#xff0c;增长了 152%。 01 中国企业存…

提升LLM效果的几种简单方法

其实这个文章想写很久了&#xff0c;最近一直在做大模型相关的产品&#xff0c;经过和团队成员一段时间的摸索&#xff0c;对大模型知识库做一下相关的认知和总结。希望最终形成一个系列。 对于知识库问答&#xff0c;现在有两种方案&#xff0c;一种基于llamaindex&#xff0…

绝地求生:[更新周报] 4/3 不停机更新:无上新、众多物品和活动即将下架!

大家好&#xff0c;我闲游盒&#xff1b;本周三4月3号&#xff0c;绝地求生不会有停机时间&#xff0c;大家可以随便玩~ ▲本周可选地图池 亚服/东南亚服&#xff1a;艾伦格、荣都、萨诺、米拉玛、帕拉莫&#xff1b; 日服/韩服KAKAO服&#xff1a;艾伦格、泰戈、萨诺、荣都、…

​港中文提出CLongEval中文基准测试集,准确评估大模型长上下文能力

论文题目&#xff1a; ClongEval: A Chinese Benchmark for Evaluating Long-Context Large Language Models 论文地址&#xff1a; https://arxiv.org/abs/2403.03514 代码地址&#xff1a; https://github.com/zexuanqiu/CLongEval 研究背景和贡献 为了使 LLM 能够支持更复杂…