当前位置: 首页 > article >正文

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

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

题目

在这里插入图片描述

题目解析及思路

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

目标节点:距离<=k

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

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

代码

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;
    }
};

http://www.kler.cn/a/419089.html

相关文章:

  • 记录OrangePi Kunpeng Pro烧录系统到固态硬盘并扩容流程
  • 详解QtPDF之 QPdfLink
  • 【热门主题】000077 物联网智能项目:开启智能未来的钥匙
  • 使用ffmpeg命令实现视频文件间隔提取帧图片
  • Linux系统盘的空间规划与内容存放指南
  • vue获取yyyyMMddHHmmss格式的日期
  • 内网使用docker搭建librespeed测速网站
  • 挑战用React封装100个组件【004】
  • UaGateway:实现OPC DA和OPC UA的高效转换
  • FFmpeg一些常用的命令
  • ElasticSearch的学习
  • JAVA中HashMap、TreeMap、LinkedHashMap 的用法与注意事项
  • 简单搭建qiankun的主应用和子应用并且用Docker进行服务器部署
  • AI高中数学教学视频生成技术:利用通义千问、MathGPT、视频多模态大模型,语音大模型,将4个模型融合 ,生成高中数学教学视频,并给出实施方案。
  • MySQL索引与分区:性能优化的关键
  • openbmc dbus架构简析(二)
  • DDR3与MIG IP核详解(一)
  • ESP32-S3模组上跑通ES8388(12)
  • SpringBoot集成swagger3
  • 【Docker】部署nginx
  • 常用元器件使用方法36:USB转串口芯片CH340X
  • 【07】MySQL中的DQL(数据查询语言)详解
  • 【JavaWeb maven基础知识总结】
  • RabbitMQ rabbitmq.conf配置文件详解
  • 算法训练营day22(二叉树08:二叉搜索树的最近公共祖先,插入,删除)
  • spring boot3.3.5 logback-spring.xml 配置