沉岛思想(BFS)-朋友圈思想(并查集)

news2025/1/20 14:55:50

在这里插入图片描述

本篇博客旨在记录自已笔记,同时希望可给小伙伴一些帮助。本人也是算法小白,水平有限,如果文章中有什么错误之处,希望小伙伴们可以在评论区指出来,共勉 💪。

沉岛思想:

题目: 给定一个包含了一些 0 和 1的非空二维数组 grid , 一个 岛屿 是由四个方向 (水平或垂直) 的 1 (代表土地) 构成的组合。你可以假设二维矩阵的四个边缘都被水包围着。

找到给定的二维数组中最大的岛屿面积。(如果没有岛屿,则返回面积为0。)

示例 1:

[[0,0,0,0,0,0,0,1,1,1,0,0,0],

[0,1,1,0,1,0,0,0,0,0,0,0,0],

[0,1,0,0,1,1,0,0,1,0,1,0,0],

[0,1,0,0,1,1,0,0,1,1,1,0,0],

[0,0,0,0,0,0,0,0,0,0,1,0,0],

[0,0,0,0,0,0,0,1,1,1,0,0,0],

[0,0,0,0,0,0,0,1,1,0,0,0,0]]

解题思路:

对于上面这个给定矩阵应返回 6。注意答案不应该是11,因为岛屿只能包含水平或垂直的四个方向的‘1’。加粗的部分就是最大面积(上下左右相邻)。

我理解的这道题就像扫雷,所有相连的1的土地的数量和就是最大面积。

需要注意的是:

要求出所有相连的1的土地的max最大值

为了避免重复访问,把搜索过的1设置为0,这就是沉岛思想。

对每一个为1的土地,从上下左右4个方向搜索值也为1的土地,以及与这些土地相连的土地。

  1. 用两个数组来实现四个方向的搜索:
d1[]={1,-1,0,0};

d2[]={0,0,1,-1};

int x=i+d1[k], y=j+d2[k]; (k=0,1,2,3)

area+=dfs(grid,x,y)
  1. 也可直接进行加减
area+=dfs(grid, i+1, j );

area+=dfs(grid, i-1, j );

area+=dfs(grid , i, j+1 );

area+=dfs(grid, i, j-1 );

代码实现:

 public static int maxAreaOfIsland(int[][] grid) {

		 int max=0;
		 for(int i=0;i<grid.length;i++){
			 for(int j=0;j<grid[i].length;j++){
				 if(grid[i][j]==1)
					 max=Math.max(max, dfs(grid,i,j));//求最大面积
			 }
		 }
		 return max;
	    }
	 public static int dfs(int[][] grid,int i,int j){
	    //边界处理
		 if(i<0||j<0||i>=grid.length||j>=grid[i].length||grid[i][j]==0){
			 return 0;
		 }
		 int area=1;
		 grid[i][j]=0;//避免重复访问
		 int d1[]={0,0,1,-1};//四个方向
		 int d2[]={1,-1,0,0};
		 for(int k=0;k<4;k++){
			 int x=d1[k]+i,y=d2[k]+j;
			 area+=dfs(grid, x, y);//递归深度优先搜索
		 }
		 return area;
	 }
}

朋友圈思想

题目: 班上有 N 名学生。其中有些人是朋友,有些则不是。他们的友谊具有是传递性。如果已知 A 是 B 的朋友,B 是 C 的朋友,那么我们可以认为 A 也是 C 的朋友。所谓的朋友圈,是指所有朋友的集合。

给定一个 N * N 的矩阵 M,表示班级中学生之间的朋友关系。如果M[i][j] = 1,表示已知第 i 个和 j 个学生互为朋友关系,否则为不知道。你必须输出所有学生中的已知的朋友圈总数。

解题思路: 这是一个典型的并查集的问题,将朋友圈中,是朋友的人加入一个并查集。在初始情况下,所有人都不是朋友,则朋友圈的数量就是人的总数,每当检测到两个朋友不在一个并查集,那么就将其加入一个并查集,然后朋友圈的总数减一。

代码实现:

class Solution {
    List<Integer> p = new ArrayList<>();
    public int findCircleNum(int[][] M) {
        int n = M.length;
        int res = n;


        for(int i = 0; i < n; i++){
            p.add(i);
        }

        for(int i = 1; i < n; i++) {
            for(int j = 0; j < i; j++) {
                if(M[i][j] == 1) {
                    if(find(i) != find(j)) {
                        res --;
                        p.set(find(i), find(j));
                    }
                }
            }
        }

        return res;

    }

    public int find(int x) {
        if(x != p.get(x)){
            p.set(x, find(p.get(x)));
        }

        return p.get(x);
    }
}

最后

对各位小伙伴有帮助的话,希望可以点赞❤️+收藏⭐,谢谢各位大佬~~🙌🙌🙌

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

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

相关文章

Sharding-JDBC之水平分库水平分表

目录 一、简介二、maven依赖三、数据库3.1、创建数据库3.2、创建表 四、配置&#xff08;二选一&#xff09;4.1、properties配置4.2、yml配置 五、实现5.1、实体5.2、持久层5.3、服务层5.4、测试类5.4.1、保存数据5.4.2、查询数据 一、简介 这里的水平分库分表是指 水平分库 …

台湾精锐APEX行星减速机直齿轮和斜齿轮有什么区别?如何选择?

台湾精锐APEX行星减速机是带太阳齿轮/行星齿轮/齿圈的机械装置。行星减速机是由太阳齿轮&#xff0c;行星齿轮的齿轮架和齿圈组成的机械装置。太阳齿轮位于中心&#xff0c;将扭矩传递到围绕太阳齿轮旋转的行星齿轮。行星齿轮和太阳齿轮位于齿圈内。 APEX减速机分为直齿轮和斜…

7.2 参数区间的估计

学习目标&#xff1a; 要学习参数的区间估计&#xff0c;我会采取以下步骤&#xff1a; 学习理论知识&#xff1a;首先&#xff0c;我会学习与参数的区间估计相关的理论知识&#xff0c;包括置信区间、抽样分布、中心极限定理、样本容量对置信区间的影响等。 掌握计算方法&am…

【小程序】小程序组件-2

目录 一. 滚轮选框 二. 音频组件 一. 滚轮选框 说真的&#xff0c;感谢微信开发者工具&#xff0c;让我这种笨比能够轻松学会这种看起来相当复杂的组件 picker组件的mode有几种模式&#xff0c;region啦&#xff0c;date啦&#xff0c;time啦&#xff0c;可以自行尝试 针对…

牛客社区项目

创建项目 认识Spring Spring Ioc Inversion 偶发Control 控制反转&#xff0c;是一种面向对象的设计思想。Dependecy Injection 依赖注入&#xff0c;是Ioc思想的实现方式。Ioc Container Ioc容器&#xff0c;是实现依赖注入的关键&#xff0c;本质上是一个工厂。 下面通过…

解决若依验证码异常:Error: image == null

前言 前两天在改项目突然发现若依的框架可以正常启动但是验证码加载不出来了&#xff0c;一直弹窗提示异常信息&#xff0c;下边是关于问题的描述和解决方案&#xff0c;没有耐心看过程的建议直接滑到最底下看解决方式 问题原因 登录页面一直提示 image null 如图 1 所示&…

最新研究!充分发挥混合量子经典算法新潜力

日本理化学研究所RIKEN的研究人员开发了一种量子计算算法&#xff0c;可高效准确地计算复杂材料中的原子级相互作用。物理学家理查德费曼于1981年首次提出量子计算机的应用&#xff0c;而该算法有可能为凝聚态物理学和量子化学带来前所未有的新局面。 量子计算机有望增强数字处…

数据格式转换(labelme、labelimg、yolo格式相互转换)

&#x1f468;‍&#x1f4bb;个人简介&#xff1a; 深度学习图像领域工作者 &#x1f389;总结链接&#xff1a; 链接中主要是个人工作的总结&#xff0c;每个链接都是一些常用demo&#xff0c;代码直接复制运行即可。包括&#xff1a; &am…

【鸿蒙应用ArkTS开发系列】- 常量类定义和使用

本篇为入门基础知识介绍&#xff0c;作为代码学习记录使用&#xff0c;请选择性阅读。 一、常量类定义 在ArkTS中&#xff0c;定一个常量很简单&#xff0c;具体如下&#xff1a; export const TAB_HOME_INDEX : number 1;export const TAB_HOME_NAME : string "首…

MobileNetV2详细原理(含torch源码)

目录 MobilneNetV2原理 MobileNetV2的创新点&#xff1a; MobileNetV2对比MobileNetV1 MobilneNetV2源码&#xff08;torch版&#xff09; 训练10个epoch的效果 MobilneNetV2原理 MobileNetV2是由谷歌开发的一种用于移动设备的轻量级卷积神经网络。与传统卷积神经网络相比…

RapidOCR调优尝试教程

目录 引言常见错例种类个别字丢失调优篇个别字识别错误调优篇情况一&#xff1a;轻量中英文模型识别对个别汉字识别错误情况二&#xff1a;轻量中英文模型对个别英文或数字识别错误 相关链接 引言 由于小伙伴们使用OCR的场景多种多样&#xff0c;单一的参数配置往往不能满足要…

qt6.2.4下载在线安装

前言 qt官网声明5.15版本以后不提供安装包安装&#xff0c;均需在线安装&#xff1a;Due to The Qt Company offering changes, open source offline installers are not available any more since Qt 5.15。此文主要记录在线安装方法及遇到问题解决方式。 一. 在线安装执行文…

mingw32-make -j$(nproc) 命令含义

系列文章目录 文章目录 系列文章目录前言一、具体操作二、使用步骤 前言 在使用krita源码编译时遇到报错&#xff1a; 这段代码是 Krita 源码中的一个 CMakeLists.txt 文件片段&#xff0c;用于配置 Krita 项目的构建系统。以下是对这段代码的解释&#xff1a; find_package(…

如何写科技论文?(以IEEE会议论文为例)

0. 写在前面 常言道&#xff0c;科技论文犹如“八股文”&#xff0c;有固定的写作模式。本篇博客主要是针对工程方面的论文的结构以及写作链条的一些整理&#xff0c;并不是为了提高或者润色一篇论文的表达。基本上所有的论文&#xff0c;都需要先构思好一些点子&#xff0c;有…

一文带你快速了解业务流程分析和流程建模

&#x1f525;业务流程分析与建模 01业务流程分析要了解的问题 有哪些业务流程&#xff1f;业务流程如何完成&#xff1f;业务流程有谁参与&#xff1f;流程中有哪些控制流&#xff08;如判断、 同步分支和会合&#xff09;&#xff1f;多个不同流程建的关系&#xff1f;完成…

JUC线程池之线程池架构

JUC线程池之线程池架构 在多线程编程中&#xff0c;任务都是一些抽象且离散的工作单元&#xff0c;而线程 是使任务异步执行的基本机制。随着应用的扩张&#xff0c;线程和任务管理也 变得非常复杂。为了简化这些复杂的线程管理模式&#xff0c;我们需要一个 “管理者”来统一…

SOLIDWORKS Composer如何实现可视化产品交互

SOLIDWORKS Composer是一款让工程师和非工程人员都能够直接访问 3D CAD 模型、并为技术交流材料创建图形内容的 3D 软件。现如今很多制造型企业都已逐步实现其产品设计流程的自动化&#xff0c;以期比竞争对手更快进入市场。但遗憾的是在很多企业中&#xff0c;技术交流内容&am…

Android之修改Jar包源码后再重新打Jar包

一、找到jar包使用框架的github源码&#xff0c;并下载 例如&#xff1a;原有jar包 找到框架源码的github地址&#xff1a; https://github.com/eclipse/paho.mqtt.android 使用git拉取源码项目到本地 二、New Module — 选择Java or Kotlin Library新建 &#xff08;1&…

RabbitMQ安装教程

目录 Erlang官网 Erlang下载 RabbitMQ官网 windows RabbitMQ docker安装rabbitmq 最近入职新公司&#xff0c;要求会RabbitMQ&#xff0c;所以自学了一下&#xff0c;现将自学的结果总结如下&#xff1a; 安装RabbitMQ之前&#xff0c;需要先安装 Erlang,因为RabbitMQ使用…

【C++初阶】缺省参数与函数重载

一.缺省参数 C祖师爷在用C写代码的时候&#xff0c;就觉得有些地方用着很不方便&#xff0c;于是就在C设计了缺省参数&#xff0c;在实现一些功能时&#xff0c;用这个就方便了许多。 1.概念 缺省参数是声明或定义函数时为函数的参数指定一个缺省值。在调用该函数时&#xff1a…