leetcode---岛屿数量

. - 力扣(LeetCode)

代码:

cpp 复制代码
//岛屿题目的思想:二维矩阵图的DFS就是,上下左右遍历如果是0或者出界的话就return
//规定的是陆地上下左右是水的话它就是岛屿。当遍历矩阵图中每一个点, 
//在调用递归算法之前结果加1,递归算法每次会把一个岛屿全部淹没 
class Solution {
public:
    int numIslands(vector<vector<char>>& grid) {
    	int m = grid.size(); 
    	int n = grid[0].size();
    	int res = 0;
    	for(int i = 0;i < m;i++){
    		for(int j = 0;j < n;j++){
    			if(grid[i][j] == '1'){
    				res++;
    				dfs(grid,i,j);
				}
			}	
		}
		return res;
	}
	void dfs(vector<vector<char>>& grid,int i,int j){
		//出界了return 
		if(i < 0 || j < 0 || i >= grid.size() || j >= grid[0].size()){
			return ;
		}
		if(grid[i][j] == '0'){
			return ;
		}
		grid[i][j] = '0';
		dfs(grid,i - 1,j);
		dfs(grid,i + 1,j);
		dfs(grid,i,j - 1);
		dfs(grid,i,j + 1);
	}
};
相关推荐
我爱C编程1 小时前
基于Qlearning强化学习的1DoF机械臂运动控制系统matlab仿真
算法
chao_7891 小时前
CSS表达式——下篇【selenium】
css·python·selenium·算法
chao_7891 小时前
Selenium 自动化实战技巧【selenium】
自动化测试·selenium·算法·自动化
YuTaoShao1 小时前
【LeetCode 热题 100】24. 两两交换链表中的节点——(解法一)迭代+哨兵
java·算法·leetcode·链表
怀旧,1 小时前
【数据结构】8. 二叉树
c语言·数据结构·算法
泛舟起晶浪1 小时前
相对成功与相对失败--dp
算法·动态规划·图论
地平线开发者2 小时前
地平线走进武汉理工,共建智能驾驶繁荣生态
算法·自动驾驶
IRevers3 小时前
【自动驾驶】经典LSS算法解析——深度估计
人工智能·python·深度学习·算法·机器学习·自动驾驶
前端拿破轮3 小时前
翻转字符串里的单词,难点不是翻转,而是正则表达式?💩💩💩
算法·leetcode·面试
凤年徐3 小时前
【数据结构与算法】203.移除链表元素(LeetCode)图文详解
c语言·开发语言·数据结构·算法·leetcode·链表·刷题