图论第6天

提高效率!!!两道题+看并查集

841.钥匙和房间

忘了把visited 加引用了:&

cpp 复制代码
class Solution {
public:
    bool canVisitAllRooms(vector<vector<int>>& rooms) {
        vector<int>visited(rooms.size(),false);
        dfs(rooms,visited,0);
        for(int i = 0;i < rooms.size();i++){
            if(visited[i] == false)return false;
        }
        return true;
    }
    void dfs(vector<vector<int>>& rooms,vector<int>&visited,int key){
        if(visited[key] == true)return;
        visited[key] = true;
        vector<int>keys = rooms[key];
        for(int i = 0; i < keys.size();i++){
            dfs(rooms,visited,keys[i]);
        }
    }
};

463. 岛屿的周长

第一是不要算重边即可。

第二是有两个挨着的岛屿就总周长减2。

第三这题不用dfs or bfs。

cpp 复制代码
class Solution {
public:
    int islandPerimeter(vector<vector<int>>& grid) {
        int island_num = 0;
        int count = 0;
        for(int i = 0;i < grid.size();i++){
            for(int j = 0;j < grid[0].size();j++){
                if(grid[i][j] == 1){
                    island_num++;
                    if((i - 1) >= 0 && grid[i-1][j] == 1)count++;
                    if((j-1) >= 0 && grid[i][j-1] == 1)count++;
                }
            }
        }
        return island_num * 4 - count * 2;
    }
};

图论还剩三道题,明天争取拿下!!!

相关推荐
笨笨饿6 分钟前
34_数据结构_栈
c语言·开发语言·数据结构·人工智能·嵌入式硬件·算法
im_AMBER18 分钟前
Leetcode 152 被围绕的区域 | 岛屿数量
数据结构·算法·leetcode·深度优先·广度优先·图搜索算法
吕司29 分钟前
LeetCode Hot Code——最大子数组和
数据结构·算法·leetcode
XiYang-DING35 分钟前
【LeetCode】144. 二叉树的前序遍历
算法·leetcode·职场和发展
WolfGang00732140 分钟前
代码随想录算法训练营 Day28 | 动态规划 part01
算法·动态规划
光电笑映1 小时前
STL 源码解密:unordered 系列容器的底层复用与哈希策略
算法·哈希算法·散列表
6Hzlia1 小时前
【Hot 100 刷题计划】 LeetCode 215. 数组中的第K个最大元素 | C++ 快速选择与堆排序题解
c++·算法·leetcode
小白菜又菜1 小时前
Leetcode 3070. Count Submatrices with Top-Left Element and Sum Less Than k
算法·leetcode·职场和发展
笨笨饿1 小时前
32_复变函数在工程中实际应用区别于联系
linux·服务器·c语言·人工智能·单片机·算法·学习方法
会编程的土豆1 小时前
【数据结构与算法】拓扑排序2
数据结构·算法·leetcode