力扣3372.连接两棵树后最大目标节点数目I

力扣3372.连接两棵树后最大目标节点数目I

题目

题目解析及思路

题目要求对于第一棵树中每个节点,使其与第二棵树的一个节点连边,返回最多的目标节点数目

目标节点:距离<=k

暴力枚举第二棵树中每个节点到其他节点距离d<=k-1的最大数量max2

再枚举第一棵树中每个节点求目标节点数量dfs(edges1),二者相加为答案ans = max2 + dfs

代码

cpp 复制代码
class Solution {
public:
    vector<vector<int>> build_tree(vector<vector<int>>& edges){
        vector<vector<int>> g(edges.size() + 1);
        for(auto& t:edges){
            //邻接矩阵
            int x = t[0],y = t[1];
            g[x].push_back(y);
            g[y].push_back(x);
        }
        return g;
    }

    int dfs(int x,int fa,int d,vector<vector<int>>& g,int k){
        if(d > k)
            return 0;
        int cnt = 1;
        //遍历
        for(int y:g[x])
            //不是父节点就继续dfs
            if(y != fa)
                cnt += dfs(y,x,d+1,g,k);
        return cnt;
    }

    vector<int> maxTargetNodes(vector<vector<int>>& edges1, vector<vector<int>>& edges2, int k) {
        int max2 = 0;
        if(k > 0){
            //建立邻接矩阵
            auto g = build_tree(edges2);
            for(int i=0;i<edges2.size()+1;i++)
                //求距离k-1的最大数目
                max2 = max(max2,dfs(i,-1,0,g,k-1));
        }

        auto g = build_tree(edges1);
        vector<int> ans(edges1.size() + 1);
        for(int i=0;i<ans.size();i++){
            ans[i] = dfs(i,-1,0,g,k) + max2;
        }
        return ans;
    }
};
相关推荐
CoovallyAIHub38 分钟前
速度暴涨10倍、成本暴降6倍!Mercury 2用扩散取代自回归,重新定义LLM推理速度
深度学习·算法·计算机视觉
CoovallyAIHub41 分钟前
实时视觉AI智能体框架来了!Vision Agents 狂揽7K Star,延迟低至30ms,YOLO+Gemini实时联动!
算法·架构·github
CoovallyAIHub1 小时前
开源:YOLO最强对手?D-FINE目标检测与实例分割框架深度解析
人工智能·算法·github
CoovallyAIHub1 小时前
OpenClaw:从“19万星标”到“行业封杀”,这只“赛博龙虾”究竟触动了谁的神经?
算法·架构·github
刀法如飞2 小时前
程序员必须知道的核心算法思想
算法·编程开发·算法思想
徐小夕3 小时前
pxcharts Ultra V2.3更新:多维表一键导出 PDF,渲染兼容性拉满!
vue.js·算法·github
CoovallyAIHub4 小时前
OpenClaw一脚踩碎传统CV?机器终于不再只是看世界
深度学习·算法·计算机视觉
CoovallyAIHub4 小时前
仅凭单目相机实现3D锥桶定位?UNet-RKNet破解自动驾驶锥桶检测难题
深度学习·算法·计算机视觉
zone77394 小时前
002:RAG 入门-LangChain 读取文本
后端·算法·面试
得物技术5 小时前
得物社区搜推公式融合调参框架-加乘树3.0实战
算法