图论第一天|797.所有可能的路径 200. 岛屿数量

Leetcode797.所有可能的路径

文章链接:代码随想录
题目链接:797.所有可能的路径

思路:深搜入门,注意邻接表和邻接矩阵的形式

class Solution {
   
public:
    vector<vector<int>> result;
    vector<int> path;
    
    void dfs(vector<vector<int>>& graph, int x){
   
        if (x == graph.size() - 1){
   
            result.push_back(path);
            return ;
        }

        for (int i = 0; i < graph[x].size(); i++){
   
            path.push_back(graph[x][i]);
            dfs(graph, graph[x][i]);
            path.pop_back();
        }
    }
    
    vector<vector<int>> allPathsSourceTarget(vector<vector<int>>& graph) {
   
        path.push_back(0);
        dfs(graph, 0);
        return result;
    }
};

Leetcode200. 岛屿数量

文章链接:代码随想录
题目链接:200. 岛屿数量

思路:深搜法

class Solution {
   
public:
    int dir[4][2] = {
   1, 0, -1, 0, 0, 1, 0, -1};
    void dfs(vector<vector<char>>& grid, vector<vector<bool>>& visited, int x, int y){
   
        for (int i = 0; i < 4; i++){
   
            int nex = x + dir[i][0];
            int ney = y + dir[i][1];
            if (nex < 0 || nex >= grid.size() || ney < 0 || ney >= grid[0].size()) continue ;
            if (!visited[nex][ney] && grid[nex][ney] == '1'){
   
                visited[nex][ney] = true;
                dfs(grid, visited, nex, ney);
            }
        }
    }
    
    
    int numIslands(vector<vector<char>>& grid) {
   
        int result = 0;
        vector<vector<bool>> visited(grid.size(), vector<bool>(grid[0].size(), 0));
        for (int i = 0; i < grid.size(); i++){
   
            for (int j = 0; j < grid[0].size(); j++){
   
                if (!visited[i][j] && grid[i][j] == '1'){
   
                    result++;
                    visited[i][j] = true;
                    dfs(grid, visited, i, j);
                }
            }
        }
        return result;
    }
};

广搜法,用队列存储,遍序搜寻,替代深搜回溯

class Solution {
   
public:
    int dir[4][2] = {
   1, 0, -1, 0, 0, 1, 0, -1};
    void bfs(vector<vector<char>>& grid, vector<vector<bool>>& visited, int x, int y){
   
        queue<pair<int, int>> que;
        que.push({
   x, y});
        visited[x][y] = true;

        while(!que.empty()){
   
            pair<int, int> cur = que.front();
            que.pop();
            for (int i = 0; i < 4; i++){
   
            int nex = cur.first + dir[i][0];
            int ney = cur.second + dir[i][1];
            if (nex < 0 || nex >= grid.size() || ney < 0 || ney >= grid[0].size()) continue ;
            if (!visited[nex][ney] && grid[nex][ney] == '1'){
   
                que.push({
   nex, ney});
                visited[nex][ney] = true;
            }
        }
        }
        
        
    }
    
    
    int numIslands(vector<vector<char>>& grid) {
   
        int result = 0;
        vector<vector<bool>> visited(grid.size(), vector<bool>(grid[0].size(), 0));
        for (int i = 0; i < grid.size(); i++){
   
            for (int j = 0; j < grid[0].size(); j++){
   
                if (!visited[i][j] && grid[i][j] == '1'){
   
                    result++;
                    
                    bfs(grid, visited, i, j);
                }
            }
        }
        return result;
    }
};

图论第一天打卡,加油!!!

相关推荐

  1. 第一|797.所有可能路径 200. 岛屿数量

    2024-01-28 06:02:01       42 阅读
  2. 797. 所有可能路径

    2024-01-28 06:02:01       32 阅读
  3. 】Leetcode 200. 岛屿数量【中等】

    2024-01-28 06:02:01       22 阅读
  4. leetcode 797.所有可能路径

    2024-01-28 06:02:01       14 阅读
  5. 第一

    2024-01-28 06:02:01       9 阅读
  6. 第二

    2024-01-28 06:02:01       8 阅读

最近更新

  1. TCP协议是安全的吗?

    2024-01-28 06:02:01       18 阅读
  2. 阿里云服务器执行yum,一直下载docker-ce-stable失败

    2024-01-28 06:02:01       19 阅读
  3. 【Python教程】压缩PDF文件大小

    2024-01-28 06:02:01       18 阅读
  4. 通过文章id递归查询所有评论(xml)

    2024-01-28 06:02:01       20 阅读

热门阅读

  1. vue项目使用element-plus

    2024-01-28 06:02:01       30 阅读
  2. 题记(32)--矩阵K次幂

    2024-01-28 06:02:01       32 阅读
  3. 【LeetCode-435】无重叠区间(贪心)

    2024-01-28 06:02:01       36 阅读
  4. el-tree实现多选、反选、指定选择

    2024-01-28 06:02:01       28 阅读
  5. Compose | UI组件(五) | Button 按钮组件

    2024-01-28 06:02:01       35 阅读
  6. 73. 矩阵置零

    2024-01-28 06:02:01       35 阅读
  7. 解析dapp:铸造虚拟钱包新概念

    2024-01-28 06:02:01       31 阅读
  8. Spark面试全攻略:深入理解与高效准备指南

    2024-01-28 06:02:01       29 阅读
  9. MySQL设计开发&使用规范

    2024-01-28 06:02:01       33 阅读