Leetcode 200.岛屿的数量 - DFS、BFS
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的更多相关文章
- [LeetCode]695. 岛屿的最大面积(DFS/BFS)、200. 岛屿数量(DFS/BFS待做/并差集待做)
695. 岛屿的最大面积 题目 给定一个包含了一些 0 和 1的非空二维数组 grid , 一个 岛屿 是由四个方向 (水平或垂直) 的 1 (代表土地) 构成的组合.你可以假设二维矩阵的四个边缘都被 ...
- Java实现 LeetCode 200 岛屿数量
200. 岛屿数量 给定一个由 '1'(陆地)和 '0'(水)组成的的二维网格,计算岛屿的数量.一个岛被水包围,并且它是通过水平方向或垂直方向上相邻的陆地连接而成的.你可以假设网格的四个边均被水包围. ...
- 力扣Leetcode 200. 岛屿数量
岛屿数量 给你一个由 '1'(陆地)和 '0'(水)组成的的二维网格,请你计算网格中岛屿的数量. 岛屿总是被水包围,并且每座岛屿只能由水平方向和/或竖直方向上相邻的陆地连接形成. 此外,你可以假设该网 ...
- LeetCode 200. 岛屿数量
习题地址 https://leetcode-cn.com/problems/number-of-islands/ 给定一个由 '1'(陆地)和 '0'(水)组成的的二维网格,计算岛屿的数量.一个岛被水 ...
- [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 ...
- LeetCode 200.岛屿的个数
给定一个由 '1'(陆地)和 '0'(水)组成的的二维网格,计算岛屿的数量.一个岛被水包围,并且它是通过水平方向或垂直方向上相邻的陆地连接而成的.你可以假设网格的四个边均被水包围. 示例 1: 输入: ...
- Leetcode 200. 岛屿的个数(扩展)
1.题目描述 给定一个由 '1'(陆地)和 '0'(水)组成的的二维网格,计算岛屿的数量.一个岛被水包围,并且它是通过水平方向或垂直方向上相邻的陆地连接而成的.你可以假设网格的四个边均被水包围. 示例 ...
- LeetCode 200. 岛屿的个数(Number of Islands)
题目描述 给定一个由 '1'(陆地)和 '0'(水)组成的的二维网格,计算岛屿的数量.一个岛被水包围,并且它是通过水平方向或垂直方向上相邻的陆地连接而成的.你可以假设网格的四个边均被水包围. 示例 1 ...
- leetcode 200岛屿的个数
主要考察图搜索: 方法一:染色法,时间O(mn) 遍历一遍,再通过BFS或DFS将所有临近岛屿染色,使用dfs时将numIslands中的bfs换成dfs即可: /***** 遍历所有的点: 只要遇见 ...
随机推荐
- config maven in intellij IDEA
Config maven in IDEA File ->Settings->Build,Execution.Deployment->build Too ...
- tf.keras 解决plot_model 的配置问题
https://blog.csdn.net/ha010/article/details/103367311
- Python随笔记录之一
import os import random from copy import deepcopy ''' 读取特定目录下所有的文件夹, 和文件名 ''' def eachDir(path): for ...
- 六、Redis五种类型 - hash(散列)类型
1.介绍 (1).hash也是一种字典结构,存储了字段(field)和字段值(value)的映射,字段值只能是字符串,不支持其他类型.(2).适合存储对象,对象列表和ID构成键名,字段表示对象的属性, ...
- C语言结构体实例-创建兔子
参考裸编程思想. #include <stdio.h> //#include "ycjobject.h" // 颜色定义 #define CL_BLACK 0 #def ...
- Springboot解决使用@Scheduled创建任务时无法在同一时间执行多个任务的BUG
1.在启动类使用 @SpringBootApplication @EnableJpaRepositories(repositoryFactoryBeanClass = MyRepositoryFact ...
- i.js
i.js 动态更新 <script type="text/javascript"> function isCardNo(idCard) { // 15位和18位身份证号 ...
- 「NOI2016」区间 解题报告
「NOI2016」区间 最近思维好僵硬啊... 一上来就觉得先把区间拆成两个端点进行差分,然后扫描位置序列,在每个位置维护答案,用数据结构维护当前位置的区间序列,但是不会维护. 于是想研究性质,想到为 ...
- BZOJ 2653: middle(主席树+二分答案)
传送门 解题思路 首先可以想到一种暴力做法,就是询问时二分,然后大于等于这个值的设为1,否则设为-1,然后就和GSS1那样统计答案.但是发现这样时间空间复杂度都很爆炸,所以考虑预处理,可以用主席树来做 ...
- postgreSQL执行计划
" class="wiz-editor-body wiz-readonly" contenteditable="false"> explain命 ...