力扣每日一题 2025.11.28

2872.可以被K整除连通块的最大数目

"困难",依旧大佬题解:

cpp 复制代码
class Solution {
public:
    int maxKDivisibleComponents(int n, vector<vector<int>>& edges, vector<int>& values, int k) {
        // 1. 构建邻接表
        vector<vector<int>> g(n);
        for (auto& e : edges) {
            int x = e[0], y = e[1];
            g[x].push_back(y);
            g[y].push_back(x);
        }
        // 2. 初始化结果计数器
        int ans = 0;
        // 3. 定义并实现 DFS  lambda 函数
        //    this auto&& dfs 是 C++14 的语法,用于在 lambda 内部递归调用自身
        //    x: 当前遍历的节点
        //    fa: x 的父节点,用于防止在邻接表中回头遍历
        //    返回值: 以 x 为根的子树的权值和
        auto dfs = [&](this auto&& dfs, int x, int fa) -> long long {
            // 4. 初始化当前子树的权值和为当前节点的值
            long long sum = values[x];
            // 5. 遍历当前节点的所有邻居
            for (int y : g[x]) {
                // 6. 如果邻居不是父节点,就递归遍历这个邻居
                if (y != fa) {
                    // 7. 将子节点 y 的子树权值和加到当前子树的权值和上
                    sum += dfs(y, x);
                }
            }
            // 8. 关键判断:如果当前子树的权值和能被 k 整除
            if (sum % k == 0) {
                ans++; // 结果加一
            }
            // 9. 返回当前子树的权值和给父节点
            return sum;
        };
        // 10. 从根节点 0 开始进行 DFS,其父节点设为 -1(表示无父节点)
        dfs(0, -1);
        // 11. 返回最终结果
        return ans;
    }
};
相关推荐
tankeven12 分钟前
HJ156 走迷宫
c++·算法
旺仔.29131 分钟前
STL排序算法详解
数据结构·算法·排序算法
酉鬼女又兒33 分钟前
零基础快速入门前端蓝桥杯Web备考:BOM与定时器核心知识点详解(可用于备赛蓝桥杯Web应用开发)
开发语言·前端·javascript·职场和发展·蓝桥杯
美狐美颜sdk37 分钟前
美颜SDK是什么?直播/短视频美颜SDK技术详解
人工智能·算法·美颜sdk·直播美颜sdk·美颜api
华农DrLai1 小时前
什么是远程监督?怎么自动生成训练数据?
人工智能·算法·llm·prompt·知识图谱
计算机安禾1 小时前
【数据结构与算法】第16篇:串(String)的定长顺序存储与朴素模式匹配
c语言·数据结构·c++·学习·算法·visual studio code·visual studio
Roselind_Yi1 小时前
【吴恩达2026 Agentic AI】面试向+项目实战(含面试题+项目案例)-2
人工智能·python·机器学习·面试·职场和发展·langchain·agent
AI科技星1 小时前
基于v≡c公设的理论优化方案
c语言·开发语言·算法·机器学习·数据挖掘
江不清丶1 小时前
垃圾收集算法深度解析:从标记-清除到分代收集的演进之路
java·jvm·算法
Roselind_Yi1 小时前
【吴恩达2026 Agentic AI】面试向+项目实战(含面试题+项目案例)-1
人工智能·python·面试·职场和发展·langchain·gpt-3·agent