图论第一天

在单位摸鱼,地铁上看了个开始,图论开了个头,后面也希望能往这个方向上转,努努力吧。

一周没做题啦,后面坚持继续做题+二刷,接着记录每一天!!!加油!!!

DFS和BFS起步:

797.所有可能的路径

DFS最基本应用

cpp 复制代码
class Solution {
public:
    vector<vector<int>>result;
    vector<int>path;
    vector<vector<int>> allPathsSourceTarget(vector<vector<int>>& graph) {
        path.push_back(0);
        findpath(graph,0);
        return result;
    }
    void findpath(vector<vector<int>>& graph,int cur){
        if(cur == graph.size() - 1){
            result.push_back(path);
            return;
        }
        for(int i = 0;i < graph[cur].size();i++){
            path.push_back(graph[cur][i]);
            findpath(graph,graph[cur][i]);
            path.pop_back();
        }
    }
};

200.岛屿数量

DFS思路主要还是要和回溯放一块搞

cpp 复制代码
class Solution {
public:
    int result = 0;
    int neighbor[4][2] = {1,0,-1,0,0,1,0,-1};
    int numIslands(vector<vector<char>>& grid) {
        int x = grid.size();
        int y = grid[0].size();
        vector<vector<bool>>visited(x,vector<bool>(y,false));
        for(int n = 0;n < x; n++){
            for(int m = 0; m < y;m++){
                if(grid[n][m] == '1' && visited[n][m] == 0){
                    visited[n][m] = 1;
                    result++;
                    dfs(grid,visited,n,m);
                }
            }
        }
        return result;
    }
    void dfs(vector<vector<char>>& grid,vector<vector<bool>>& visited,int x,int y){
        for(int i = 0;i < 4;i++){
            int nextx = x + neighbor[i][0];
            int nexty = y + neighbor[i][1];
            if(nextx < 0 || nexty < 0 || nextx >= grid.size() || nexty >= grid[0].size())continue;
            if(visited[nextx][nexty] == 0 && grid[nextx][nexty] == '1'){
                visited[nextx][nexty] = 1;
                dfs(grid,visited,nextx,nexty);
            }
        }
    }
};

BFS主要是while循环

cpp 复制代码
class Solution {
public:
    int result = 0;
    int neighbor[4][2] = {1,0,0,1,-1,0,0,-1};
    int numIslands(vector<vector<char>>& grid) {
        int n = grid.size();
        int m = grid[0].size();
        vector<vector<bool>>visited(n,vector<bool>(m,false));
        for(int i = 0;i < n;i++){
            for(int j =0;j <m;j++){
                if(visited[i][j] == 0 && grid[i][j] == '1'){
                    result++;
                    bfs(grid,visited,i,j);
                }
            }
        }
        return result;
    }
    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] = 1;
        while(!que.empty()){
            pair<int,int>cur = que.front();
            que.pop();
            for(int i = 0;i < 4;i++){
                int nextx = cur.first + neighbor[i][0];
                int nexty = cur.second + neighbor[i][1];
                if(nextx < 0 || nexty < 0 || nextx >= grid.size() || nexty >= grid[0].size())continue;
                if(visited[nextx][nexty] == 0 && grid[nextx][nexty] == '1'){
                que.push({nextx,nexty});
                visited[nextx][nexty] = 1;
                }
            }
        }
    }
};

今天就这两道题,明天接着来~摸鱼!!!

相关推荐
月明长歌1 小时前
【码道初阶】Leetcode155踩坑最小栈问题:最小栈:算法对了,却输给了 Java 的 “==“?
java·算法·
我送炭你添花1 小时前
Pelco KBD300A 模拟器:05.校验算法终极对比 + 完整 100+ 指令封装 + KBD300A 所有隐藏功能函数化
python·算法·自动化·运维开发
DuHz1 小时前
汽车FMCW雷达互扰下的快速目标检测:谱峰累积法与泊松CFAR精读与推导
论文阅读·算法·目标检测·汽车·信息与通信·信号处理
2401_837088501 小时前
算法边界情况处理套路总结
算法
烛衔溟1 小时前
C语言图论:最短路径算法
c语言·算法·图论·dijkstra·bellman-ford·最短路径
烛衔溟1 小时前
C语言图论:最小生成树算法
c语言·算法·图论·最小生成树·kruskal·prim
Yzzz-F1 小时前
算法竞赛进阶指南 进阶搜索
算法·深度优先
weixin_437546332 小时前
注释文件夹下脚本的Debug
java·linux·算法
月明长歌2 小时前
【码道初阶】【LeetCode 572】另一棵树的子树:当“递归”遇上“递归”
算法·leetcode·职场和发展
月明长歌2 小时前
【码道初阶】【LeetCode 150】逆波兰表达式求值:为什么栈是它的最佳拍档?
java·数据结构·算法·leetcode·后缀表达式