博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Leetcode 200.岛屿的数量 - DFS、BFS
阅读量:5365 次
发布时间:2019-06-15

本文共 1772 字,大约阅读时间需要 5 分钟。

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
>& 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
>& grid) { int result = 0; for (int i=0; i
class Solution {  // BFS解法,12ms/11MB, 96.9% / 69.4%public:    queue
> q; void bfs_set_zero(vector
>& 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
=0 && grid[pos.first][pos.second-1] == '1') q.emplace(pos.first,pos.second-1); if (pos.second+1
>& grid) { int result = 0; for (int i=0; i

转载于:https://www.cnblogs.com/dylanchu/p/11326423.html

你可能感兴趣的文章
无缝滚动-另类-移动端
查看>>
VMware Funsion 修改vmnet1/vmnet8默认网络地址及DHCP地址
查看>>
R学习笔记之三:对象
查看>>
EasyUI基础入门之Pagination(分页)
查看>>
一次PHP代码上线遇到的问题
查看>>
显示密码
查看>>
实现one hot encode独热编码的两种方法
查看>>
ubuntu中文英文环境切换
查看>>
[sql]mysql启停脚本
查看>>
[elk]Mutate filter plugin增删改查字段
查看>>
mysql的查询、子查询及连接查询
查看>>
Java内功心法,行为型设计模式
查看>>
向github项目push代码后,Jenkins实现其自动构建
查看>>
C语言时间头文件
查看>>
Java8中的 lambda 和Stream API
查看>>
兼容性测试相关
查看>>
对称排序
查看>>
走进MySQL
查看>>
Remove Duplicates from Sorted Array
查看>>
Java 反射机制
查看>>