class Solution { public: /** * 判断岛屿数量 * @param grid char字符型vector<vector<>> * @return int整型 */ int solve(vector<vector<char> >& grid) { int row = grid.size(); int col = grid[0].size(); int res = 0; vector<vector<bool>> visited(row, vector<bool>(col)); for(int i=0; i<row; i++){ for(int j=0; j<col; j++){ if(grid[i][j] == '0' || visited[i][j]) continue; dfs(grid, visited, i, j); res++; } } return res; // write code here } void dfs(vector<vector<char>>& grid, vector<vector<bool>>& visited, int i, int j){ if(i>=grid.size() || i<0 || j>=grid[0].size() || j<0 || visited[i][j] || grid[i][j] == '0') return; visited[i][j] = true; dfs(grid, visited, i+1, j); dfs(grid, visited, i-1, j); dfs(grid, visited, i, j+1); dfs(grid, visited, i, j-1); } };
https://www.cnblogs.com/grandyang/p/4402656.html