本周学习了DFS,因此在LeetCode中挑选了一道关于DFS的题目作为巩固。
题目:200. Number of Islands
Given a 2d grid map of '1'
s (land) and '0'
s (water), count the number of islands. An island is surrounded by water and is formed by connecting adjacent lands horizontally or vertically. You may assume all four edges of the grid are all surrounded by water.
Example 1:
11110
11010
11000
00000
Answer: 1
Example 2:
11000
11000
00100
00011
Answer: 3
题解:
这道题是经典的通过DFS求联通块的题目。由于grid中每一个点都有可能是成为发现的新island中的第一个点,于是在主函数(numIslands)中,需要对每一个陆地元素为起点进行DFS。在主函数中的每一次DFS结束之后,说明已经完成了一个岛屿的遍历,因此需要对岛屿总数计数器进行递增。
对于DFS中的操作,一般而言对于图的DFS遍历,都通过一个visited二维数组来判断这个节点是否遍历过,但是这里由于题目的特性,可以通过将已经遍历过的陆地置0求得。也就是说,在每一次DFS中,将当前节点grid值置零,然后判断这个节点的上下左右邻域是否越界。如果不越界,并且是陆地,就继续DFS递归下去。
class Solution { public: void dfs(vector<vector<char>>& grid, int y, int x) { int rows = grid.size(); int cols = grid[0].size(); if(x>=cols || x<0 || y<0 || y>=rows) return; grid[y][x] = '0'; //说明已经遍历过了这个节点 if(x-1>=0 && grid[y][x-1] == '1') dfs(grid,y,x-1); if(y-1>=0 && grid[y-1][x] == '1') dfs(grid,y-1,x); if(x+1 < cols && grid[y][x+1] =='1') dfs(grid,y,x+1); if(y+1 < rows && grid[y+1][x] =='1') dfs(grid,y+1,x); } int numIslands(vector<vector<char>>& grid) { if(grid.empty()) return 0; int totalIsland = 0; int rows = grid.size(); int cols = grid[0].size(); for(int i = 0 ; i < rows ; i ++) { for(int j = 0 ; j < cols; j ++) { if(grid[i][j]=='1') { dfs(grid,i,j); //当每一次完成这样的遍历之后,就说明一个岛已经遍历完 totalIsland ++; } } } return totalIsland; } };