力扣-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;
    }
};
相关推荐
TracyCoder12317 小时前
LeetCode Hot100(15/100)——54. 螺旋矩阵
算法·leetcode·矩阵
u01092727118 小时前
C++中的策略模式变体
开发语言·c++·算法
2501_9418372619 小时前
停车场车辆检测与识别系统-YOLOv26算法改进与应用分析
算法·yolo
六义义20 小时前
java基础十二
java·数据结构·算法
四维碎片20 小时前
QSettings + INI 笔记
笔记·qt·算法
Tansmjs20 小时前
C++与GPU计算(CUDA)
开发语言·c++·算法
独自破碎E21 小时前
【优先级队列】主持人调度(二)
算法
weixin_4454766821 小时前
leetCode每日一题——边反转的最小成本
算法·leetcode·职场和发展
打工的小王21 小时前
LeetCode Hot100(一)二分查找
算法·leetcode·职场和发展
Swift社区21 小时前
LeetCode 385 迷你语法分析器
算法·leetcode·职场和发展