这是悦乐书的第238次更新,第251篇原创

01 看题和准备

今天介绍的是LeetCode算法题中Easy级别的第105题(顺位题号是463)。您将获得一个二维整数网格形式的地图,其中1代表土地,0代表水。网格单元水平/垂直(不是对角线)连接。 网格完全被水包围,并且恰好有一个岛(即,一个或多个连接的陆地小区)。

岛上没有“湖泊”(里面的水与岛周围的水没有联系)。 一个单元格是边长为1的正方形。网格为矩形,宽度和高度不超过100。确定岛的周长。

输入:[[0,1,0,0],[1,1,1,0],[0,1,0,0],[1,1,0,0]]

输出:16

说明:周边是下图中的16条黄色条纹:



本次解题使用的开发工具是eclipse,jdk使用的版本是1.8,环境是win7 64位系统,使用Java语言编写和测试。

02 第一种解法

此题的题意是要求我们根据提供的二维数组,来计算二维数组中元素为1(代表边长为1的正方形)所组成图形的周长。

计算周长,一是需要知道该图形由多少个小正方形(元素为1)组成,二是减去相邻小正方形之间重叠的两边。我们直接使用两层循环,在内层循环中,如果当前元素值为1,表示遇到了正方形,周长就加4,此时我们就需要判断其右边和下边有没有挨着的正方形,如果有就要减去2,最后返回周长。

public int islandPerimeter(int[][] grid) {
if (grid == null || grid.length == 0) {
return 0;
}
int perimeter = 0;
for (int i=0; i<grid.length; i++) {
for (int j=0; j<grid[0].length; j++) {
if (grid[i][j] == 1) {
perimeter += 4;
// 向右判断,有重叠就减去2
if (j+1 < grid[i].length && grid[i][j+1] == 1) {
perimeter -= 2;
}
// 向下判断,有重叠就减去2
if (i+1 < grid.length && grid[i+1][j] == 1) {
perimeter -= 2;
}
}
}
}
return perimeter;
}

03 第二种解法

同样使用两层循环,当某一元素值为1的时候,我们去判断它的上下左右是不是等于0,从而计算它单独的边,即没有与其他正方形连接的边,也就是题目示例中,所给图例中标黄的线。

public int islandPerimeter2(int[][] grid) {
if (grid == null || grid.length == 0) {
return 0;
}
int perimeter = 0, len = grid.length, len2 = grid[0].length;
for (int i=0; i<len; i++) {
for (int j=0; j<len2; j++) {
if (grid[i][j] == 1) {
if (i == 0 || grid[i-1][j] == 0) {
perimeter++;
}
if (i == len-1 || grid[i+1][j] == 0) {
perimeter++;
}
if (j == 0 || grid[i][j-1] == 0) {
perimeter++;
}
if (j == len2-1 || grid[i][j+1] == 0) {
perimeter++;
}
}
}
}
return perimeter;
}

04 小结

算法专题目前已日更超过三个月,算法题文章105+篇,公众号对话框回复【数据结构与算法】、【算法】、【数据结构】中的任一关键词,获取系列文章合集。

以上就是全部内容,如果大家有什么好的解法思路、建议或者其他问题,可以下方留言交流,点赞、留言、转发就是对我最大的回报和支持!

最新文章

  1. SharePoint Configuration Wizard - Unable to upgrade SharePoint Products and Technologies because an upgrade is already in progress
  2. ubuntu 安装配置ssh
  3. 如何去除My97 DatePicker控件上右键弹出官网的链接 - 如何debug混淆过的代码
  4. jqgrid动态显示/隐藏某一列
  5. setTimeout用法
  6. Mysql一主多从和读写分离配置简记
  7. bzoj1237
  8. Area - POJ 1265(pick定理求格点数+求多边形面积)
  9. servlet的filter的使用
  10. angular destroy &amp; jquery destroy
  11. LeetCode 53. Maximum Subarray(最大的子数组)
  12. [ZJOI2010]基站选址
  13. React(五)State属性
  14. bzoj3237(cdq+并查集)
  15. Java 容器 &amp; 泛型:六、容器讲到为什么要使用泛型
  16. 将1~n个整数按照字典序进行排序
  17. 用Rider写一个有IOC容器Autofac的.net core的程序
  18. List中存放字符串进行排序
  19. C++ 学习 之Struct
  20. TDD 与 BDD 仅仅是语言描述上的区别么?

热门文章

  1. Quartz.NET学习笔记(四) 计划任务触发器
  2. Java__线程---基础知识全面实战---坦克大战系列为例
  3. 『Asp.Net 组件』Asp.Net 服务器组件 内嵌图片:自己的图片控件
  4. TCP/IP 四次断开
  5. 使用MQ来保证分布式事务的最终一致性
  6. Typora中的Markdown教程
  7. eclipse 创建maven 项目 动态web工程完整示例 maven 整合springmvc整合mybatis
  8. 第59章 IdentityServer交互服务 - Identity Server 4 中文文档(v1.0.0)
  9. Redis面试点
  10. nginx系列1:认识nginx