Leetcode 200 岛屿的数量:

DFS利用函数调用栈保证了检索顺序,

BFS则需要自己建立队列,把待检索对象按规则入队。

class Solution {  // DFS解法,8ms/10.7MB,99.7% / 92%
public: /**
* row,col: 坐标,以0开始.
* 用row和col,而不是x,y. 否则容易写成grid[x][y],顺序不对!!
*/
void dfs_set_zero(vector<vector<char>>& grid, int row, int col) {
int n_rows = grid.size();
if (!n_rows) return;
int n_cols = grid[0].size();
if (!n_cols) return; if (row<0 || row>=n_rows || col<0 || col>=n_cols) return; if (grid[row][col] == '1') {
grid[row][col] = '0';
dfs_set_zero(grid, row-1, col);
dfs_set_zero(grid, row+1, col);
dfs_set_zero(grid, row, col-1);
dfs_set_zero(grid, row, col+1);
}
} int numIslands(vector<vector<char>>& grid) {
int result = 0;
for (int i=0; i<grid.size(); ++i) {
for (int j=0; j<grid[0].size(); ++j) {
if (grid[i][j] == '1') {
result++;
dfs_set_zero(grid, i, j);
}
}
}
return result;
}
};
class Solution {  // BFS解法,12ms/11MB, 96.9% / 69.4%
public:
queue<pair<int,int>> q; void bfs_set_zero(vector<vector<char>>& grid) {
int n_rows = grid.size();
if(!n_rows) return;
int n_cols = grid[0].size();
if(!n_cols) return; while (!q.empty()) {
auto pos = q.front();
q.pop();
//if (grid[pos.first][pos.second] == '1') {
grid[pos.first][pos.second] = '0';
if (pos.first-1>=0 && grid[pos.first-1][pos.second] == '1')
q.emplace(pos.first-1,pos.second);
if (pos.first+1<n_rows && grid[pos.first+1][pos.second] == '1')
q.emplace(pos.first+1,pos.second);
if (pos.second-1>=0 && grid[pos.first][pos.second-1] == '1')
q.emplace(pos.first,pos.second-1);
if (pos.second+1<n_cols && grid[pos.first][pos.second+1] == '1')
q.emplace(pos.first,pos.second+1);
//}
}
} int numIslands(vector<vector<char>>& grid) {
int result = 0;
for (int i=0; i<grid.size(); i++) {
for (int j=0; j<grid[0].size(); j++) {
if (grid[i][j] == '1') {
result++;
//q.push(make_pair(i,j));
q.emplace(i,j); // 使用emplace而非push,constructed in-place
// 其实这种方式和 q.push( {i,j} );是相同的(右值引用),详见 “C++11的初始化方式”https://blog.csdn.net/K346K346/article/details/55194246
bfs_set_zero(grid);
}
}
}
return result;
}
};

Leetcode 200.岛屿的数量 - DFS、BFS的更多相关文章

  1. [LeetCode]695. 岛屿的最大面积(DFS/BFS)、200. 岛屿数量(DFS/BFS待做/并差集待做)

    695. 岛屿的最大面积 题目 给定一个包含了一些 0 和 1的非空二维数组 grid , 一个 岛屿 是由四个方向 (水平或垂直) 的 1 (代表土地) 构成的组合.你可以假设二维矩阵的四个边缘都被 ...

  2. Java实现 LeetCode 200 岛屿数量

    200. 岛屿数量 给定一个由 '1'(陆地)和 '0'(水)组成的的二维网格,计算岛屿的数量.一个岛被水包围,并且它是通过水平方向或垂直方向上相邻的陆地连接而成的.你可以假设网格的四个边均被水包围. ...

  3. 力扣Leetcode 200. 岛屿数量

    岛屿数量 给你一个由 '1'(陆地)和 '0'(水)组成的的二维网格,请你计算网格中岛屿的数量. 岛屿总是被水包围,并且每座岛屿只能由水平方向和/或竖直方向上相邻的陆地连接形成. 此外,你可以假设该网 ...

  4. LeetCode 200. 岛屿数量

    习题地址 https://leetcode-cn.com/problems/number-of-islands/ 给定一个由 '1'(陆地)和 '0'(水)组成的的二维网格,计算岛屿的数量.一个岛被水 ...

  5. [LeetCode] 130. Surrounded Regions_Medium tag: DFS/BFS

    Given a 2D board containing 'X' and 'O' (the letter O), capture all regions surrounded by 'X'. A reg ...

  6. LeetCode 200.岛屿的个数

    给定一个由 '1'(陆地)和 '0'(水)组成的的二维网格,计算岛屿的数量.一个岛被水包围,并且它是通过水平方向或垂直方向上相邻的陆地连接而成的.你可以假设网格的四个边均被水包围. 示例 1: 输入: ...

  7. Leetcode 200. 岛屿的个数(扩展)

    1.题目描述 给定一个由 '1'(陆地)和 '0'(水)组成的的二维网格,计算岛屿的数量.一个岛被水包围,并且它是通过水平方向或垂直方向上相邻的陆地连接而成的.你可以假设网格的四个边均被水包围. 示例 ...

  8. LeetCode 200. 岛屿的个数(Number of Islands)

    题目描述 给定一个由 '1'(陆地)和 '0'(水)组成的的二维网格,计算岛屿的数量.一个岛被水包围,并且它是通过水平方向或垂直方向上相邻的陆地连接而成的.你可以假设网格的四个边均被水包围. 示例 1 ...

  9. leetcode 200岛屿的个数

    主要考察图搜索: 方法一:染色法,时间O(mn) 遍历一遍,再通过BFS或DFS将所有临近岛屿染色,使用dfs时将numIslands中的bfs换成dfs即可: /***** 遍历所有的点: 只要遇见 ...

随机推荐

  1. css-目标伪类选择器:target的应用

    目标伪类选择器:target是众多CSS3众多 动态 伪类选择器中的一个,用来匹配锚点指向的元素,突出显示活动的HTML锚. <style> p:target{ border: 2px s ...

  2. BioGRID 互作数据库

    01 — BioGRID BioGRID 是 Biological General Repository for Interactionh Datasets 的缩写(网址为 https://thebi ...

  3. PHP disk_total_space() 函数

    定义和用法 disk_total_space() 函数返回指定目录的磁盘总容量,以字节为单位. 语法 disk_total_space(directory) 参数 描述 directory 必需.规定 ...

  4. java web项目的https配置

    1.进入到jdk下的bin目录 keytool -v -genkey -alias tomcat -keyalg RSA -keystore d:/tomcat.keystore -validity ...

  5. paper 140:TLD视觉跟踪算法(超棒)

    我是看了这样的一个视频:http://www.56.com/u83/v_NTk3Mzc1NTI.html 然后在准备针对TLD视觉跟踪算法来个小的总结. 以下博文转自:http://blog.csdn ...

  6. 网络-Docker 提供的几种原生网络和自定义网络(11)

    Docker 网络从覆盖范围可分为单个 host 上的容器网络和跨多个 host 的网络,本章重点讨论前一种 Docker 安装时会自动在 host 上创建三个网络,我们可用 docker netwo ...

  7. 尚学linux课程---11、vim操作命令1

    尚学linux课程---11.vim操作命令1 一.总结 一句话总结: 要看不同的视频,每个视频的关键点都不一样,不如之间的的视频就没讲到vim中set nu是什么意思 1.Vi有三种基本工作模式? ...

  8. 动态规划及LCS

    LCS的python实现: #!/usr/bin/env python #-*- coding: utf-8 -*- import sys reload(sys) sys.setdefaultenco ...

  9. vue input框type=number 保留两位小数自定义组件

    第一步:自定义组件MyNumberInput.vue<template> <input class="numberInput" type="number ...

  10. JPA派生标识符2

    @Entity@Table(name = "adam_importfile")@IdClass(BusinessAdviserFileId.class)public class B ...