leetcode-岛屿数量-99

题目要求

思路

1.使用广度优先遍历,将数组中所有为1的元素遍历一遍,遍历过程中使用递归,讲该元素的上下左右四个方向的元素值也置为0

2.统计一共执行过多少次,次数就是岛屿数量
代码实现

cpp 复制代码
class Solution {
public:
    int solve(vector<vector<char> >& grid) {
        int n = grid.size();
        int m = grid[0].size();
        int index = 0;
        for(int i = 0; i < n; i++)
        {
            for(int j = 0; j < m; j++)
            {
                if(grid[i][j] == '1')
                {
                    index++;
                    // cout << i << " " << j <<endl;
                    dfs(grid, i, j);
                }
            }
        }
        return index;
    }

    void dfs(vector<vector<char>>& grid, int i, int j)
    {
        if(grid[i][j] == '1')
            grid[i][j] = '0';

        if(i > 0 && grid[i-1][j] == '1')
            dfs(grid, i-1, j);
        if(j > 0 && grid[i][j-1] == '1')
            dfs(grid, i, j-1);
        if(i < grid.size() - 1 && grid[i+1][j] == '1')
            dfs(grid, i+1, j);
        if(j < grid[0].size() - 1 && grid[i][j+1] == '1')
            dfs(grid, i, j+1);
    }
};
相关推荐
ULTRA??1 天前
QT向量类实现GJK碰撞检测算法3d版本
c++·qt·算法
天赐学c语言1 天前
12.10 - 合并两个有序链表 && 对字节对齐的理解
数据结构·c++·leetcode·链表
仰泳的熊猫1 天前
1092 To Buy or Not to Buy
数据结构·c++·算法·pat考试
罗湖老棍子1 天前
【深基16.例3】二叉树深度(洛谷P4913)
数据结构·算法·二叉树
Charlo1 天前
Open-AutoGLM Windows 安装部署教程
算法·设计模式·github
君义_noip1 天前
信息学奥赛一本通 4017:【GESP2309三级】小杨的储蓄 | 洛谷 B3867 [GESP202309 三级] 小杨的储蓄
c++·算法·gesp·信息学奥赛
高山上有一只小老虎1 天前
判断是否为数独数组
java·算法
宝贝儿好1 天前
【强化学习】第二章:老虎机问题、ε-greedy算法、指数移动平均
人工智能·python·算法
CoovallyAIHub1 天前
超越深度学习:量子优化如何通过算法与硬件重塑AI
深度学习·算法·计算机视觉