LeetCode Hot 100 -- 图论

岛屿数量

java 复制代码
class Solution {

    // dfs 模板
    public static int[][] dir = {{0, 1}, {1, 0}, {-1, 0},{0, -1}};
    public static void dfs(boolean[][] visited, int x, int y, char[][] grid) {
        for (int i = 0; i < 4; i++) {
            int nextX = x + dir[i][0];
            int nextY = y + dir[i][1];
            if (nextX < 0 || nextY < 0 || nextX >= grid.length || nextY >= grid[0].length) continue;  // 越界
            // 下一个位置没有被访问过,且为 1
            if (!visited[nextX][nextY] && grid[nextX][nextY] == '1') {
                visited[nextX][nextY] = true;  // 标记为已访问
                dfs(visited, nextX, nextY, grid);  // 使用递归搜索相邻的格子
            }
        }
    }

    public int numIslands(char[][] grid) {
        int m = grid.length;
        int n = grid[0].length;
        int ans = 0;
        boolean[][] visited = new boolean[m][n];
        
        // 解题思路:找到未被标记,且图上为 1 的点,然后找出其周围的所有 1,这就可以看作找到了一个岛屿,继续重复这个操作就可以找到岛屿的数量
        for (int i = 0; i < m; i++) {
            for (int j = 0; j < n; j++) {
                if (!visited[i][j] && grid[i][j] == '1') {
                    ans++;  
                    visited[i][j] = true;
                    dfs(visited, i, j, grid);
                }
            }
        }
        return ans;
    }
}
java 复制代码
class Solution {
    // 逆时针,下右上左
    public static int[][] dir = {{0, 1}, {1, 0}, {0, -1}, {-1, 0}}; 
    static class pair {
        int first, second;
        pair(int x, int y) {
            this.first = x;
            this.second = y;
        }
    }
    public static void bfs(boolean[][] visited, int x, int y, char[][] grid) {
       Queue<pair> queue = new LinkedList<pair>();
       queue.add(new pair(x, y));
       visited[x][y] = true;
       while (!queue.isEmpty()) {
        int curX = queue.peek().first;
        int curY = queue.poll().second;
        for (int i = 0; i < 4; i++) {
            int nextX = curX + dir[i][0];
            int nextY = curY + dir[i][1];
            if (nextX < 0 || nextY < 0 || nextX >= grid.length || nextY >= grid[0].length) continue;
            if (!visited[nextX][nextY] && grid[nextX][nextY] == '1') {
                // 使用队列来进行 bfs
                queue.add(new pair(nextX, nextY));
                visited[nextX][nextY] = true;
            }
         }
      }
    }

    public int numIslands(char[][] grid) {
        int m = grid.length;
        int n = grid[0].length;
        int ans = 0;
        boolean[][] visited = new boolean[m][n];
        for (int i = 0; i < m; i++) {
            for (int j = 0; j < n; j++) {
                if (!visited[i][j] && grid[i][j] == '1') {
                    ans++;
                    bfs(visited, i, j, grid);
                }
            }
        }
        return ans;
    }
    
    
}

课程表

java 复制代码
class Solution {
    public boolean canFinish(int numCourses, int[][] prerequisites) {
        // 构建图
        List<Integer>[] graph = new List[numCourses];  // 图的邻接表
        for (int i = 0; i < numCourses; i++) {
            graph[i] = new ArrayList<>();
        }
        for (int[] pre : prerequisites) {
            graph[pre[1]].add(pre[0]);
        }

        // 用于 DFS 判断环的状态数组
        int[] visited = new int[numCourses];

        // 对每个课程进行 DFS 遍历
        for (int i = 0; i < numCourses; i++) {
            if(hasCycle(graph, visited, i)) {
                return false;
            }
        }
        
        return true;
    }


    private boolean hasCycle(List<Integer>[] graph, int[] visited, int course) {
        if (visited[course] == 1) {
            return true;
        }
        if (visited[course] == 2) {
            return false;
        }

        visited[course] = 1;
        for (int neighbor : graph[course]) {
            if (hasCycle(graph, visited, neighbor)) {
                return true;
            }
        }

        visited[course] = 2;
        
        return false;
    }
}

邻接表:graph = \[, 0, 1 ],表示课程1依赖课程0,课程2依赖课程1

相关推荐
8Qi826 分钟前
LeetCode 121 & 122:股票买卖问题(DP 对比题解)✅
算法·leetcode·职场和发展·动态规划
一只齐刘海的猫37 分钟前
【Leetcode】 接雨水
java·算法·leetcode
菜菜的顾清寒1 小时前
力扣HOT(100)54多维动态规划-最长公共子序列
算法·leetcode·动态规划
8Qi84 小时前
LeetCode 198:打家劫舍(House Robber)—— 题解 ✅
算法·leetcode·动态规划
Lucis__4 小时前
图的高阶算法:从构造最小生成树到求解最短路径问题
数据结构·c++·算法·图论
8Qi812 小时前
LeetCode 235. 二叉搜索树的最近公共祖先(LCA)
算法·leetcode·二叉树·递归·二叉搜索树·lca·迭代
8Qi814 小时前
LeetCode 494:目标和(Target Sum)—— 题解 ✅
算法·leetcode·职场和发展·动态规划·01背包
这料鬼有毒17 小时前
二刷hot100-78.子集
算法·leetcode·职场和发展
随意起个昵称18 小时前
线性dp-LIS题目2(导弹拦截III)
算法·动态规划·图论
医用门19 小时前
医院钢制门厂家有哪些品牌好的
leetcode