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. package.json和package-lock.json的区别

    参考:https://blog.csdn.net/c2311156c/article/details/80320046 package.json: 主要用来定义项目中需要依赖的包 package-lo ...

  2. div标准布局示例

    <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title> ...

  3. 第二则java读取excel文件代码

    // 得到上传文件的保存目录,将上传的文件存放于WEB-INF目录下,不允许外界直接访问,保证上传文件的安全 String savePath = this.getServletContext().ge ...

  4. linux rsync 复制文件忽略文件夹

    比如: /home/vagrant/test 目录下有 a,b,c 三个文件夹,只复制 c 文件夹下面的文件到/home/vagrant/test2 下 使用cp命令复制的时候,只能排除一个目录不被复 ...

  5. Java 的内置对象

    1.Request对象 该对象封装了用户提交的信息,通过调用该对象相应的方法可以获取封装的信息,即使用该对象可以获取用户提交的信息.    当Request对象获取客户提交的汉字字符时,会出现乱码问题 ...

  6. leetcode-165周赛-1276-不浪费原料的汉堡制作方案

    题目描述: 自己的提交: class Solution: def numOfBurgers(self, tomatoSlices: int, cheeseSlices: int) -> List ...

  7. 阿里云HBase推出普惠性高可用服务,独家支持用户的自建、混合云环境集群

    HBase可以支持百TB数据规模.数百万QPS压力下的毫秒响应,适用于大数据背景下的风控和推荐等在线场景.阿里云HBase服务了多家金融.广告.媒体类业务中的风控和推荐,持续的在高可用.低延迟.低成本 ...

  8. bzoj 2013

    http://www.lydsy.com/JudgeOnline/problem.php?id=2013 最初看这个题的时候,以为神题不可做,然后去找yzjc..然后做法过于简单了(' '       ...

  9. padding 填充

    CSS padding(填充)是一个简写属性,定义元素边框与元素内容之间的空间,即上下左右的内边距. padding(填充) 当元素的 padding(填充)内边距被清除时,所释放的区域将会受到元素背 ...

  10. CF1061E Politics E. Politics 解题报告

    CF1061E Politics E. Politics 考虑利用树的性质,因为是子树问题,所以放到dfs序上. 只考虑一个树,问题是每个区间选恰好\(k\)个.因为区间其实是子树,所以区间要么包含, ...