力扣-463.岛屿的周长

Idea

注意观察,每一个完整的方块,边长都是加4,一旦这个方块有其他的方块相邻的话,那么这两个方块总边长就要减少2.

因此我们遍历二维数组的时候,判断岛屿方块的上面还有左方是否有相邻即可

cpp 复制代码
class Solution {
public:
    int islandPerimeter(vector<vector<int>>& grid) {
        int m = grid.size();
        int n = grid[0].size();
        int ans = 0;
        for(int i = 0; i < m; i++) {
            for(int j = 0; j < n; j++) {
                if(grid[i][j]) {
                    ans += 4;
                    if(i - 1 >= 0 && grid[i - 1][j]) ans -= 2;
                    if(j - 1 >= 0 && grid[i][j - 1]) ans -= 2;
                }
            }
        }
        return ans;
    }
};
相关推荐
天一生水water4 分钟前
基于FFT的频域故障诊断
人工智能·算法·智慧油田
石去皿14 分钟前
数据结构与算法面试核心考点精要
java·算法·面试
今儿敲了吗18 分钟前
18| 差分数组
c++·笔记·学习·算法
Bear on Toilet30 分钟前
BFS_FloodFill_46 . 腐烂的橘子问题
数据结构·c++·算法·leetcode·宽度优先
大模型玩家七七31 分钟前
关系记忆不是越完整越好:chunk size 的隐性代价
java·前端·数据库·人工智能·深度学习·算法·oracle
样例过了就是过了32 分钟前
LeetCode热题100 找到字符串中所有字母异位词
算法·leetcode
DevilSeagull33 分钟前
C语言: C语言内存函数详解
c语言·开发语言·算法
搞科研的小刘选手40 分钟前
【人工智能专题】2026年人工智能与生成式设计国际学术会议(ICAIGD 2026)
人工智能·算法·aigc·生成式ai·学术会议·计算机工程·生成式设计
stripe-python1 小时前
十二重铲雪法(上)
c++·算法
ccLianLian2 小时前
计算机基础·cs336·RLHF
深度学习·算法