[HOT 100] 1617. 统计子树中城市之间最大距离

文章目录

      • 1. 题目链接
      • 2. 题目描述
      • 3. 题目示例
      • 4. 解题思路
      • 5. 题解代码
      • 6. 复杂度分析

1. 题目链接


1617. 统计子树中城市之间最大距离 - 力扣(LeetCode)

2. 题目描述


给你 n 个城市,编号为从 1n 。同时给你一个大小为 n-1 的数组 edges ,其中 edges[i] = [ui, vi] 表示城市 uivi 之间有一条双向边。题目保证任意城市之间只有唯一的一条路径。换句话说,所有城市形成了一棵 树 。

一棵 子树 是城市的一个子集,且子集中任意城市之间可以通过子集中的其他城市和边到达。两个子树被认为不一样的条件是至少有一个城市在其中一棵子树中存在,但在另一棵子树中不存在。

对于 d1n-1 ,请你找到城市间 最大距离 恰好为 d 的所有子树数目。

请你返回一个大小为 n-1 的数组,其中第 d 个元素(下标从 1 开始)是城市间 最大距离 恰好等于 d 的子树数目。

请注意,两个城市间距离定义为它们之间需要经过的边的数目。


3. 题目示例


示例 1 :

输入:n = 4, edges = [[1,2],[2,3],[2,4]]
输出:[3,4,0]
解释:
子树 {1,2}, {2,3} 和 {2,4} 最大距离都是 1 。
子树 {1,2,3}, {1,2,4}, {2,3,4} 和 {1,2,3,4} 最大距离都为 2 。
不存在城市间最大距离为 3 的子树。

示例 2 :

输入:n = 2, edges = [[1,2]]
输出:[1]

4. 解题思路

  1. 问题理解
    • 给定一棵树,统计所有连通子图
    • 对每个可能的直径d,计算有多少子图的直径等于d
    • 直径定义为子图中最长路径的边数
  2. 核心算法
    • 使用回溯法枚举所有可能的节点子集(2^n种可能)
    • 对每个子集检查是否构成连通子图
    • 计算连通子图的直径并统计结果
  3. 直径计算
    • 采用树形DP方法
    • 通过DFS计算每个节点的最长路径
    • 在递归过程中维护全局直径
  4. 连通性检查
    • 比较访问标记数组和选择数组
    • 两者一致说明子图连通

5. 题解代码


class Solution {private List<Integer>[] g; // 邻接表存储树结构private boolean[] inSet;    // 记录哪些节点在当前子集中private boolean[] vis;      // DFS访问标记private int[] ans;          // 结果数组,ans[d]表示直径为d+1的子图数量private int n, diameter;   // n是节点总数,diameter记录当前子图的直径public int[] countSubgraphsForEachDiameter(int n, int[][] edges) {this.n = n;// 初始化邻接表g = new ArrayList[n];Arrays.setAll(g, e -> new ArrayList<>());// 构建树结构(节点编号转为0-based)for (var e : edges) {int x = e[0] - 1, y = e[1] - 1;g[x].add(y);g[y].add(x);}ans = new int[n - 1]; // 直径范围是1到n-1inSet = new boolean[n];f(0); // 开始递归枚举所有子集return ans;}// 递归枚举所有可能的节点子集private void f(int i) {// 递归终止条件:处理完所有节点if (i == n) {// 检查当前子集是否构成连通子图for (int v = 0; v < n; ++v)if (inSet[v]) {vis = new boolean[n];diameter = 0;dfs(v); // 从第一个选中的节点开始DFSbreak;}// 如果子图连通且直径有效,更新结果if (diameter > 0 && Arrays.equals(vis, inSet))++ans[diameter - 1];return;}// 不选当前节点if(i + 1);// 选当前节点iinSet[i] = true;f(i + 1);inSet[i] = false; // 回溯}// 计算子图的直径(同时标记访问过的节点)private int dfs(int x) {vis[x] = true;int maxLen = 0; // 记录从x出发的最长路径长度for (int y : g[x])if (!vis[y] && inSet[y]) { // 只考虑选中的且未访问的邻居int ml = dfs(y) + 1;  // 递归计算子节点路径长度diameter = Math.max(diameter, maxLen + ml); // 更新直径maxLen = Math.max(maxLen, ml); // 更新当前最大长度}return maxLen;}
}

6. 复杂度分析


时间复杂度:O(n * 2^n)

  • 枚举所有子集:O(2^n)
  • 对每个子集进行DFS:O(n)
  • 总复杂度为两者的乘积

空间复杂度:O(n)

  • 邻接表存储空间:O(n)
  • 递归调用栈深度:O(n)
  • 各种标记数组:O(n)

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/904120.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

接口自动化——参数化

之前有说过&#xff0c;通过pytest测试框架标记参数化功能可以实现数据驱动测试。数据驱动测试使用的文件主要有以下类型&#xff1a; txt 文件 csv 文件excel 文件json 文件yaml 文件.... 本文主要讲的就是以上几种文件类型的读取和使用 一.txt 文件读取使用 首先创建一个 …

游戏引擎学习第257天:处理一些 Win32 相关的问题

设定今天的工作计划 今天我们本来是打算继续开发性能分析器&#xff08;Profiler&#xff09;&#xff0c;但在此之前&#xff0c;我们认为有一些问题应该先清理一下。虽然这类事情不是我们最关心的核心内容&#xff0c;但我们觉得现在是时候处理一下了&#xff0c;特别是为了…

实验三 触发器及基本时序电路

1.触发器的分类&#xff1f;各自的特点是什么&#xff1f; 1 、 D 触发器 特点&#xff1a;只有一个数据输入端 D &#xff0c;在时钟脉冲的触发沿&#xff0c;输出 Q 的状态跟随输入端 D 的 状态变化&#xff0c;即 &#xff0c;功能直观&#xff0c;利于理解和感受…

硬件加速模式Chrome(Edge)闪屏

Chrome开启“硬件加速模式”后&#xff0c;打开浏览器会闪屏或看视频会闪屏&#xff0c;如果电脑只有集显&#xff0c;直接将这个硬件加速关了吧&#xff0c;没啥必要开着 解决方法 让浏览器使用独立显卡 在Windows左下角搜索 图形设置 &#xff0c;将浏览器添加进去&#…

前端工程化利器:Node.js 文件匹配库 fast-glob 完全指南——比传统方案快 350% 的「文件搜索神器」

为什么需要 fast-glob&#xff1f; 在前端工程化场景中&#xff0c;文件匹配是高频操作&#xff1a;自动化构建、资源打包、静态资源管理等都依赖高效的路径匹配。传统的 node-glob 虽然功能齐全&#xff0c;但性能瓶颈明显。fast-glob 应运而生——它以 极简 API 和 超高性能…

React class 的组件库与函数组件适配集成

如果你有一个 基于 React class 的组件库&#xff0c;现在需要在 React hooks 函数组件中使用&#xff0c;你可以通过以下几种方式实现适配和集成&#xff1a; 数据生命周期确保 class 组件使用 React.forwardRef 导出&#xff08;或手动绑定 ref&#xff09; ✅ 1. 直接使用 c…

Sway初体验

Sway&#xff08;缩写自 SirCmpwn’s Wayland compositor[1]&#xff09;是一款专为 Wayland 设计的合成器&#xff0c;旨在与 i3 完全兼容。根据官网所述&#xff1a; Sway 是 Wayland 的合成器&#xff0c;也是 x11 的 i3 窗口管理器的替代品。它可以根据您现有的 i3 配置工作…

dubbo 参数校验-ValidationFilter

org.apache.dubbo.rpc.Filter 核心功能 拦截RPC调用流程 Filter是Dubbo框架中实现拦截逻辑的核心接口&#xff0c;作用于服务消费者和提供者的作业链路&#xff0c;支持在方法调用前后插入自定义逻辑。如参数校验、异常处理、日志记录等。扩展性机制 Dubbo通过SPI扩展机制动态…

Lesson 16 A polite request

Lesson 16 A polite request 词汇 park n. 公园&#xff0c;停车场&#xff0c;庄园 v. 停车&#xff0c;泊车 例句&#xff1a;让我来停车。    Let me park. 相关&#xff1a;spot n. 车位 区别&#xff1a;garden n. 花园 [小&#xff0c;私家的] 例句&#xff1a;我们…

解决 Builroot 系统编译 perl 编译报错问题

本文提供一种修复 Builroot 系统编译 perl 编译报错途径 2025-05-04T22:45:08 rm -f pod/perl5261delta.pod 2025-05-04T22:45:08 /usr/bin/ln -s perldelta.pod pod/perl5261delta.pod 2025-05-04T22:45:08 /usr/bin/gcc -c -DPERL_CORE -fwrapv -fpcc-struct-return -pipe -f…

Spring MVC 中解决中文乱码问题

在 Spring MVC 中解决中文乱码问题&#xff0c;需要从 请求参数编码 和 响应内容编码 两方面入手。以下是完整的解决方案&#xff1a; 一、解决请求参数中文乱码 1. POST 请求编码&#xff08;表单提交&#xff09; 配置 CharacterEncodingFilter 在 web.xml 中添加 Spring 提…

MYSQL数据库突然消失

之前在下载mysql时发现没有my.ini。考虑到后面的项目可能需要&#xff0c;看着教程自己创建了一次&#xff0c;当时就发生了所有数据库消失的问题&#xff0c;近几天这种事件又发生了。我在服务里看到我有mysql和mysql57两个服务&#xff0c;启动一个的时候另一个就无法启动&am…

【Spring】idea + maven 从零创建Spring IoC容器示例

【Spring】idea maven 从零创建Spring IoC容器示例 1. 环境准备2. 创建maven项目3. 添加依赖4. 创建Java类与接口4.1 定义接口UserService4.2 实现接口UserServiceImpl 5. 配置Spring IoC容器6. 编写主类调用IoC容器扩展&#xff1a;使用注解方式实现IoC1. 修改beans.xml2.使用…

面试回答之STAR结构

面试回答之STAR结构 1. STAR结构的起源 STAR是行为面试法&#xff08;Behavioral Interview&#xff09;的核心框架&#xff0c;由以下四个单词首字母组成&#xff1a; • Situation&#xff08;情境&#xff09; • Task&#xff08;任务&#xff09; • Action&#xff…

Kubernetes部署运行应用

①使用 Deployment 运行一个无状态应用 ②运行一个单实例有状态应用 ③运行一个有状态的应用程序 ④使用 Persistent Volumes 部署 WordPress 和 MySQL

二叉搜索树的最近祖先(递归遍历)

235. 二叉搜索树的最近公共祖先 - 力扣&#xff08;LeetCode&#xff09; class Solution { private:TreeNode*traversal(TreeNode*cur,TreeNode*p,TreeNode*q){if(curNULL){return NULL;}if(cur->val>p->val&&cur->val>q->val){TreeNode*lefttrave…

网络:TCP三次握手、四次挥手

目录 深刻理解三次握手 深刻理解四次挥手 深刻理解三次握手 三次握手时&#xff0c;如果最后一个ACK包&#xff0c;服务器没有收到&#xff0c;此时&#xff1a; 客户端&#xff1a;认为已经建立链接 服务器&#xff1a;认为没有建立链接&#xff0c;还在超时等待。 而此…

MySQL 实战 45 讲 笔记 ----来源《极客时间》

01 | 基础架构&#xff1a;一条SQL查询语句是如何执行的&#xff1f; 1. MySQL 可以分为 Server层 和 存储引擎层 两部分。Server 层包括连接器、查询缓存、分析器、优化器、执行器等。存储引擎层支持 InnoDB、MyISAM等. (1) 连接器&#xff1a;管理连接&#xff0c;权限认证…

nextjs+supabase vercel部署失败

1.不能含有<any> 改成unknown或者增加类(如图) 2.检查vecel是否配置环境变量&#xff08;即supabase的url和anon-key&#xff09;

数据库Mysql_联合查询

或许自己的不完美才是最完美的地方&#xff0c;那些让自己感到不安的瑕疵&#xff0c;最终都会变成自己的特色。 ----------陳長生. 1.介绍 1.1.为什么要进行联合查询 在数据设计的时候&#xff0c;由于范式的需求&#xff0c;会被分为多个表&#xff0c;但是当我们要查询数据…