leetcode2368. 受限条件下可到达节点的数目-medium

1 题目:受限条件下可到达节点的数目

官方标定难度:中

现有一棵由 n 个节点组成的无向树,节点编号从 0 到 n - 1 ,共有 n - 1 条边。

给你一个二维整数数组 edges ,长度为 n - 1 ,其中 edgesi = ai, bi 表示树中节点 ai 和 bi 之间存在一条边。另给你一个整数数组 restricted 表示 受限 节点。

在不访问受限节点的前提下,返回你可以从节点 0 到达的 最多 节点数目。

注意,节点 0 不 会标记为受限节点。

示例 1:

输入:n = 7, edges = \[0,1,1,2,3,1,4,0,0,5,5,6], restricted = 4,5

输出:4

解释:上图所示正是这棵树。

在不访问受限节点的前提下,只有节点 0,1,2,3 可以从节点 0 到达。

示例 2:

输入:n = 7, edges = \[0,1,0,2,0,5,0,4,3,2,6,5], restricted = 4,2,1

输出:3

解释:上图所示正是这棵树。

在不访问受限节点的前提下,只有节点 0,5,6 可以从节点 0 到达。

提示:

2 <= n <= 105

edges.length == n - 1

edgesi.length == 2

0 <= ai, bi < n

ai != bi

edges 表示一棵有效的树

1 <= restricted.length < n

1 <= restrictedi < n

restricted 中的所有值 互不相同

2 solution

dfs 搜索没有限制的节点即可

代码

cpp 复制代码
class Solution {
    static int const N = 1e5 + 1;
    vector<int> e[N];
    bitset<N> rest;

    int dfs(int u, int p) {
        int ans = 1;
        for (int v: e[u]) {
            if (v != p && !rest.test(v)) {
                ans += dfs(v, u);
            }
        }
        return ans;
    }

public:
    int reachableNodes(int n, vector<vector<int>> &edges, vector<int> &restricted) {
        for (auto &x: edges) {
            e[x[0]].push_back(x[1]);
            e[x[1]].push_back(x[0]);
        }

        for (int v: restricted) rest.set(v);

        return dfs(0, -1);
    }
};

结果

相关推荐
小许同学记录成长3 分钟前
网格简化算法 — Edge Collapse(边塌缩)
qt·算法
Swift社区3 分钟前
OpenHarmony鸿蒙PC平台移植 gifsicle:CC++ 三方库适配实践(Lycium tpc_c_cplusplus)
c语言·c++·harmonyos
凯瑟琳.奥古斯特6 分钟前
力扣1001网格照明解法
算法·leetcode·职场和发展
fengenrong9 分钟前
20260601
算法·深度优先·图论
晚笙coding11 分钟前
从“看起来像双指针”到真正的动态规划 —— 最长公共子序列
算法·动态规划
basketball61621 分钟前
C++进阶:1. 引用折叠规则
java·开发语言·c++
05候补工程师24 分钟前
【考研高数核心突破】极限的本质、高频解题套路与海涅定理深度解析(附经典例题思维导图式拆解)
经验分享·笔记·考研·算法
酬勤-人间道28 分钟前
VTK 与 Cesium-native 结合实践:小场景三维编辑 + 数字地球精准贴合
c++·qt·vtk·遥感·岩土·cesium-native
智者知已应修善业28 分钟前
【51单片机8个LED的花样12亮34熄56间隔78闪烁3秒3闪烁】2023-11-4
c++·经验分享·笔记·算法·51单片机
老鱼说AI34 分钟前
统计学习方法第五章:从浅入深解析决策树
人工智能·深度学习·算法·决策树·机器学习·学习方法