代码随想录图论 第五天| 841.钥匙和房间 463. 岛屿的周长

代码随想录图论 第五天| 841.钥匙和房间

一、 841.钥匙和房间

题目链接:https://leetcode.cn/problems/keys-and-rooms/

思路:钥匙就是索引,遍历过就标记,每拿到一个房间的钥匙,直接for循环递归遍历,深度优先直接拿下。

java 复制代码
class Solution {
    public boolean canVisitAllRooms(List<List<Integer>> rooms) {
        boolean[] visited = new boolean[rooms.size()];
        dfs(visited, rooms, 0);
        for (boolean b : visited) {
            if (b == false) return false;
        }
        return true;
    }
    void dfs(boolean[] visited, List<List<Integer>> rooms, int key) {
        if (visited[key]) return;
        visited[key] = true;
        List<Integer> list = rooms.get(key);
        for (Integer i : list) {
            dfs(visited, rooms, i);
        }
    }
}

二、463. 岛屿的周长

题目链接:https://leetcode.cn/problems/island-perimeter/

思路:常规思路,遍历每一个岛屿并且计算当前点的边长就可以。

java 复制代码
class Solution {
    int sum = 0;
    public int islandPerimeter(int[][] grid) {
        for (int i = 0; i < grid.length; i++) {
            for (int j = 0; j < grid[0].length; j++) {
                if (grid[i][j] == 1) {
                    dfs(grid, i, j);
                    return sum;
                }
            }
        }
        return sum;
    }
    
    void dfs(int[][] grid, int x, int y) {
        if (x < 0 || x >= grid.length || y < 0 || y >= grid[0].length) {
            return;
        }
        if (grid[x][y] == 2 || grid[x][y] == 0) return;
        grid[x][y] = 2;
        if (x-1 < 0 || grid[x-1][y] == 0) sum++;
        if (x+1 >= grid.length || grid[x+1][y] == 0) sum++;
        if (y-1 < 0 || grid[x][y-1] == 0) sum++;
        if (y+1 >= grid[0].length || grid[x][y+1] == 0) sum++;
        
        dfs(grid, x-1, y);
        dfs(grid, x+1, y);
        dfs(grid, x, y-1);
        dfs(grid, x, y+1);
    }
}
相关推荐
晨曦_子画5 分钟前
编程语言之战:AI 之后的 Kotlin 与 Java
android·java·开发语言·人工智能·kotlin
软工菜鸡25 分钟前
预训练语言模型BERT——PaddleNLP中的预训练模型
大数据·人工智能·深度学习·算法·语言模型·自然语言处理·bert
南宫生28 分钟前
贪心算法习题其三【力扣】【算法学习day.20】
java·数据结构·学习·算法·leetcode·贪心算法
Heavydrink41 分钟前
HTTP动词与状态码
java
ktkiko1144 分钟前
Java中的远程方法调用——RPC详解
java·开发语言·rpc
AI视觉网奇1 小时前
sklearn 安装使用笔记
人工智能·算法·sklearn
计算机-秋大田1 小时前
基于Spring Boot的船舶监造系统的设计与实现,LW+源码+讲解
java·论文阅读·spring boot·后端·vue
神里大人1 小时前
idea、pycharm等软件的文件名红色怎么变绿色
java·pycharm·intellij-idea
JingHongB1 小时前
代码随想录算法训练营Day55 | 图论理论基础、深度优先搜索理论基础、卡玛网 98.所有可达路径、797. 所有可能的路径、广度优先搜索理论基础
算法·深度优先·图论
weixin_432702261 小时前
代码随想录算法训练营第五十五天|图论理论基础
数据结构·python·算法·深度优先·图论