我的编程空间,编程开发者的网络收藏夹
学习永远不晚

Android岛屿数量算法怎么使用

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

Android岛屿数量算法怎么使用

这篇文章主要介绍“Android岛屿数量算法怎么使用”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“Android岛屿数量算法怎么使用”文章能帮助大家解决问题。

岛屿数量

之前接触过一个算法,比较有意思,可以拿出来说说,这个算法是这样的。

给一个01矩阵,1代表是陆地,0代表海洋, 如果两个1相邻,那么这两个1属于同一个岛。我们只考虑上下左右为相邻。(岛屿: 相邻陆地可以组成一个岛屿(相邻:上下左右) 判断岛屿个数。)

比如

输入

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

输出3。因为1相连的就3块

那这道题要如何做呢,其实有个思路,我去遍历二维数组,判断到如果为1,我就把与1相连的上下左右都置0,这样在接下来的遍历中就不会受到已统计数量的影响。

如果只听这样的描述还是没理解也没关系,可以看看代码,我这是用java写的,挺简单的,应该能很容易看懂。

public class Solution {        public int solve (char[][] grid) {        int total = 0;        if(grid.length == 0 || grid[0].length == 0){            return total;        }        int wl = grid[0].length;        for(int i=0; i < grid.length; i++){            for(int j =0; j < wl; j++){                if(grid[i][j] == '1'){                    total++;                    cancel(grid, i, j);                }            }        }        return total;    }    private void cancel(char[][] grid, int i, int j){        if(grid[i][j] == '1'){            grid[i][j] = '0';            if(i > 0){                cancel(grid, i-1, j);            }            if(j > 0){                cancel(grid, i, j-1);            }            if(j < grid[0].length -1){                cancel(grid, i, j+1);            }            if(i < grid.length - 1){                cancel(grid, i+1, j);            }        }    }}

那能从这个算法中学会什么呢?学会了这道算法,被问到就有题库了【狗头】,那也太血亏了,还是要扩展一下思路。

我觉得有意思的地方在于,它是通过一个反向的思路,去设置状态,以此来把这个问题变得更简单。

有个比较基础的坑,在循环中删除元素,这是会出问题的。假设我有一堆学生,我生日了要发出邀请,我想把所有的男生都给排除掉。

public class Student {    public int sex; // 男是1}
List<Student> students = new getAllStudents();for (int i = 0; i < students.size(); i++) {    if (students.get(i).sex == 1){        students.remove(students.get(i));    }}

这样写肯定会出问题,这是一个也算是经典的BUG场景了,相信所有人都碰到过。因为我们的思路是“排除所有男生”,但是如果反着去想,这个问题也就很好解决,反着就是“保留所有女生”

List<Student> students = new getAllStudents();List<Student> girls = new ArrayList<>();for (int i = 0; i < students.size(); i++) {    if (students.get(i).sex == 0){        girls.add(students.get(i));    }}students = girls;

应该没什么问题吧,我直接就在这写了,类似伪代码那种,大概懂什么意思就行,这个其实就是copy and write

虽然这个场景可能不能很好的表现出这个思路,但是意思就是如果我们开发中碰到一些问题或者复杂的逻辑流程,我们可以试着反着思考,说不定会有更好的出路。

关于“Android岛屿数量算法怎么使用”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识,可以关注编程网行业资讯频道,小编每天都会为大家更新不同的知识点。

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

Android岛屿数量算法怎么使用

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

Android岛屿数量算法怎么使用

这篇文章主要介绍“Android岛屿数量算法怎么使用”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“Android岛屿数量算法怎么使用”文章能帮助大家解决问题。岛屿数量之前接触过一个算法,比较有意思,
2023-07-05

Android开发岛屿数量算法示例解析

这篇文章主要为大家介绍了Android开发岛屿数量算法示例解析,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
2023-03-01

java回文数算法怎么使用

要判断一个数字是否为回文数,可以使用以下算法:将数字转换为字符串。使用两个指针,一个指向字符串的开头,一个指向字符串的末尾。比较两个指针指向的字符是否相等,如果不相等,则该数字不是回文数。如果相等,将两个指针向中间移动,继续比较。当
2023-10-23

Apriori算法怎么使用

Apriori算法是一种用于挖掘频繁项集和关联规则的算法。其主要思想是通过迭代的方式,从候选项集中找出频繁项集,并使用频繁项集来生成下一轮的候选项集。以下是Apriori算法的使用步骤:准备数据集:将数据集表示为一个二维列表或一个事务数据
2023-10-26

Android二分查找算法怎么用

本篇内容主要讲解“Android二分查找算法怎么用”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Android二分查找算法怎么用”吧!旋转数组的最小数字题目:把一个数组最开始的若干个元素搬到数组
2023-06-04

Java对数器验证算法怎么使用

本文小编为大家详细介绍“Java对数器验证算法怎么使用”,内容详细,步骤清晰,细节处理妥当,希望这篇“Java对数器验证算法怎么使用”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。对数器验证算法的正确性对数器介绍1
2023-07-06

Android onFinishInflate方法怎么使用

在Android中,onFinishInflate方法是View类中的一个方法,用于在View被inflate(填充)后调用。具体使用方法如下:1. 在自定义的View类中,重写onFinishInflate方法。代码示例:```javap
2023-10-12

android inflate方法怎么使用

在Android中,`inflate()`方法主要是用来将一个布局文件转换为对应的View对象,即将XML布局文件转换为Java对象。`inflate()`方法的使用步骤如下:1. 首先,获取一个`LayoutInflater`的实例,可以
2023-08-24

Python dHash算法怎么使用

这篇文章主要介绍“Python dHash算法怎么使用”,在日常操作中,相信很多人在Python dHash算法怎么使用问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”Python dHash算法怎么使用”的疑
2023-06-30

android数据库怎么使用

在Android中,可以使用SQLite数据库进行数据存储和检索。以下是使用Android数据库的一般步骤:1. 创建数据库:在Android应用程序的`SQLiteOpenHelper`子类中创建数据库。在`onCreate()`方法中,
2023-08-17

php雪花算法怎么使用

PHP雪花算法是一个生成唯一ID的算法,可以用于分布式系统中,避免ID冲突。下面是一个示例代码,演示如何在PHP中使用雪花算法:```phpclass Snowflake{const EPOCH = 1479533469598;const
2023-08-25

怎么使用Python贪心算法

这篇文章主要介绍“怎么使用Python贪心算法”,在日常操作中,相信很多人在怎么使用Python贪心算法问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”怎么使用Python贪心算法”的疑惑有所帮助!接下来,请跟
2023-06-16

vue2的diff算法怎么使用

这篇文章主要介绍“vue2的diff算法怎么使用”,在日常操作中,相信很多人在vue2的diff算法怎么使用问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”vue2的diff算法怎么使用”的疑惑有所帮助!接下来
2023-07-04

编程热搜

  • Python 学习之路 - Python
    一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
    Python 学习之路 - Python
  • chatgpt的中文全称是什么
    chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
    chatgpt的中文全称是什么
  • C/C++中extern函数使用详解
  • C/C++可变参数的使用
    可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
    C/C++可变参数的使用
  • css样式文件该放在哪里
  • php中数组下标必须是连续的吗
  • Python 3 教程
    Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
    Python 3 教程
  • Python pip包管理
    一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
    Python pip包管理
  • ubuntu如何重新编译内核
  • 改善Java代码之慎用java动态编译

目录