[HOT 100] 2646. 最小化旅行的价格总和

文章目录

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

1. 题目链接


2646. 最小化旅行的价格总和 - 力扣(LeetCode)


2. 题目描述


现有一棵无向、无根的树,树中有 n 个节点,按从 0n - 1 编号。给你一个整数 n 和一个长度为 n - 1 的二维整数数组 edges ,其中 edges[i] = [ai, bi] 表示树中节点 aibi 之间存在一条边。

每个节点都关联一个价格。给你一个整数数组 price ,其中 price[i] 是第 i 个节点的价格。

给定路径的 价格总和 是该路径上所有节点的价格之和。

另给你一个二维整数数组 trips ,其中 trips[i] = [starti, endi] 表示您从节点 starti 开始第 i 次旅行,并通过任何你喜欢的路径前往节点 endi

在执行第一次旅行之前,你可以选择一些 非相邻节点 并将价格减半。

返回执行所有旅行的最小价格总和。


3. 题目示例


示例 1 :

输入:n = 4, edges = [[0,1],[1,2],[1,3]], price = [2,2,10,6], trips = [[0,3],[2,1],[2,3]]
输出:23
解释:
上图表示将节点 2 视为根之后的树结构。第一个图表示初始树,第二个图表示选择节点 0 、2 和 3 并使其价格减半后的树。
第 1 次旅行,选择路径 [0,1,3] 。路径的价格总和为 1 + 2 + 3 = 6 。
第 2 次旅行,选择路径 [2,1] 。路径的价格总和为 2 + 5 = 7 。
第 3 次旅行,选择路径 [2,1,3] 。路径的价格总和为 5 + 2 + 3 = 10 。
所有旅行的价格总和为 6 + 7 + 10 = 23 。可以证明,23 是可以实现的最小答案。

示例 2 :

输入:n = 2, edges = [[0,1]], price = [2,2], trips = [[0,0]]
输出:1
解释:
上图表示将节点 0 视为根之后的树结构。第一个图表示初始树,第二个图表示选择节点 0 并使其价格减半后的树。 
第 1 次旅行,选择路径 [0] 。路径的价格总和为 1 。 
所有旅行的价格总和为 1 。可以证明,1 是可以实现的最小答案。

4. 解题思路


  1. 问题理解
    • 给定一棵树,每个节点有一个价格。
    • 多个旅行路径(trips),每个路径从起点到终点。
    • 可以选择将某些节点的价格减半,但相邻节点不能同时减半。
    • 目标是最小化所有旅行路径的总价格。
  2. 关键步骤
    • 统计节点访问次数:通过DFS遍历每个trip的路径,统计每个节点被访问的次数。
    • 动态规划计算最小总价格:类似"打家劫舍III"问题,对每个节点有两种选择(减半或不变),需要满足相邻节点不能同时减半的条件。
  3. DFS统计访问次数
    • 对每个trip,从起点DFS到终点,标记路径上的所有节点。
    • 使用cnt数组记录每个节点被访问的总次数。
  4. 动态规划设计
    • 状态定义dp(x)返回一个数组[notHalve, halve],表示节点x不减半或减半时的最小总价格。
    • 状态转移
      • 如果x不减半,子节点可以减半或不变,取最小值。
      • 如果x减半,子节点必须不减半。
    • 初始化:叶子节点的notHalvehalve直接计算。

5. 题解代码


class Solution {private List<Integer>[] g;  // 邻接表存储树结构private int[] price, cnt;    // price: 节点价格数组, cnt: 节点访问次数数组private int end;             // 当前trip的目标节点public int minimumTotalPrice(int n, int[][] edges, int[] price, int[][] trips) {// 初始化邻接表g = new ArrayList[n];Arrays.setAll(g, e -> new ArrayList<>());for (int[] e : edges) {int x = e[0], y = e[1];g[x].add(y);g[y].add(x);}// 初始化节点访问次数数组cnt = new int[n];// 处理每个trip,统计路径上的节点访问次数for (int[] t : trips) {end = t[1];dfs(t[0], -1);}this.price = price;// 动态规划计算最小总价格int[] res = dp(0, -1);return Math.min(res[0], res[1]);}// DFS统计trip路径上的节点访问次数private boolean dfs(int x, int fa) {if (x == end) {cnt[x]++;return true; // 找到目标节点}for (int y : g[x]) {if (y != fa && dfs(y, x)) {cnt[x]++; // 当前节点在路径上return true;}}return false; // 未找到目标节点}// 动态规划计算最小总价格(类似打家劫舍III)private int[] dp(int x, int fa) {int notHalve = price[x] * cnt[x]; // 当前节点价格不减半的总价格int halve = notHalve / 2;         // 当前节点价格减半的总价格for (int y : g[x]) {if (y != fa) {int[] res = dp(y, x); // 子节点的计算结果notHalve += Math.min(res[0], res[1]); // 当前节点不减半,子节点可以减半或不变halve += res[0]; // 当前节点减半,子节点必须不变}}return new int[]{notHalve, halve};}
}

6. 复杂度分析


时间复杂度

  • DFS统计访问次数:O(n * m),其中n是节点数,m是trip数量(每个trip最坏O(n))。
  • 动态规划:O(n),每个节点处理一次。
  • 总时间复杂度:O(n * m + n) = O(n * m)。

空间复杂度

  • 邻接表:O(n)。
  • cnt数组:O(n)。
  • 递归调用栈:最坏O(n)。
  • 总空间复杂度:O(n)。

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

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

相关文章

分析 Docker 磁盘占用

以下是分析 Docker 磁盘占用的详细步骤和工具指南&#xff0c;帮助开发者快速定位和清理冗余数据&#xff1a; 1. 查看 Docker 磁盘使用概览 docker system df 输出说明&#xff1a; TYPE TOTAL ACTIVE SIZE RECLAIMABLE Images 15 …

聊一聊接口测试中的参数化测试

目录 一、核心概念 二、适用场景 三、参数化测试的核心目的 四、实现参数化测试的关键步骤 4.1 定义测试数据 4.2 使用测试框架参数化功能 4.3 执行测试与结果分析 五、最佳实践与注意事项 六、工具推荐 那参数化测试的目的是什么&#xff1f;应该是为了提高测试覆盖率…

Go语言——string、数组、切片以及map

一、string、数组、切片代码 package mainimport "fmt"// 定义结构体 type student struct {id intname stringage intscore float32 }func main() {// 使用var声明切片var slice1 []intslice1 append(slice1, 1)slice1 append(slice1, 2)slice1 append(sl…

Android 开发中JDK 的使用和配置详解

前些天发现了一个蛮有意思的人工智能学习网站,8个字形容一下"通俗易懂,风趣幽默",感觉非常有意思,忍不住分享一下给大家。 👉点击跳转到教程 在安卓开发中, 我们会使用到Java的JDK, JDK全程为(Java Development Kit)意思是:Java开发工具包。那么JDK 与我们的…

MPay码支付系统第四方聚合收款码多款支付插件个人免签支付源码TP8框架全开源

一、源码描述 这是一套码支付源码&#xff08;MPay&#xff09;&#xff0c;基于TP8框架&#xff0c;前端layui2.9后端PearAdmin&#xff0c;专注于个人免签收款&#xff0c;通过个人的普通收款码&#xff0c;即可实现收款通知自动回调&#xff0c;支持绝大多数商城系统&#…

国产数据库铸就数字基建新基石,助力农业产业转型升级

中国科技企业以自主创新突破技术壁垒&#xff0c;为全球产业链重构注入新动能。广东辰宜信息科技有限公司&#xff08;以下简称“辰宜科技”&#xff09;凭借自主研发的“博流分布式多模数据库”等核心技术&#xff0c;作为支持数据流通的关键技术支撑&#xff0c;实现中国基础…

《人工智能:如何重塑教育模式与学习图景》

《人工智能&#xff1a;如何重塑教育模式与学习图景》 引言 人工智能&#xff0c;特别是大型语言模型&#xff08;如GPT-4/ChatGPT&#xff09;&#xff0c;正以前所未有的速度影响教育领域。从基础教育到高等教育&#xff0c;再到职业教育&#xff0c;传统教学模式正在被重新审…

硬件工程师面试常见问题(14)

第六十六问&#xff1a;运放--输入偏置电流和输入失调电流 输入偏置电流lb&#xff1a;是由于运放两个输入极都有漏电流的存在。实际的运放,会有电流流入运放的输入端的。那么输入偏置电流就定义这两个电流的平均值。 输入失调电流 Ios&#xff1a;定义为两个差分输入端偏置电…

Docker+Kubernetes落地指南:从单机到集群的平滑迁移

一、为何必须升级到Kubernetes&#xff1f; 1.1 单机Docker的瓶颈 单机环境痛点&#xff1a; ├─ 资源利用率不均衡&#xff08;CPU飙高 vs 内存闲置&#xff09; ├─ 服务扩容需手动操作 ├─ 零宕机更新难以实现 └─ 网络配置复杂&#xff08;跨主机通信困难&am…

HttpPrinter 是一款功能强大的跨平台 Web 打印解决方案

HttpPrinter 是一款功能强大的跨平台 Web 打印解决方案&#xff0c;支持多种编程语言和打印场景&#xff0c;适用于企业级报表打印、静默打印、远程打印等需求。以下是其核心功能、技术特点及使用方法的综合分析&#xff1a; 一、核心功能与特点 跨平台与多语言支持 支持 Java…

Selenium Web自动化测试学习笔记(一)

自动化测试 技术手段模拟人工&#xff0c;执行重复性任务&#xff0c;准确率100%&#xff0c;高于人工 selenium 可通过浏览器驱动控制浏览器&#xff0c;通过元素定位模拟人工&#xff0c;实现web自动化&#xff0c;没有焦点&#xff08;把浏览器放在最小化依然可以&#x…

TikTok 矩阵运营新手实操保姆级教程 2.0 版本

在当下这个全球化的数字浪潮中&#xff0c;TikTok 这片充满机遇的流量蓝海&#xff0c;正吸引着无数创业者和品牌方争相角逐。而要想在这激烈的竞争中脱颖而出&#xff0c;TikTok 矩阵运营无疑是至关重要的制胜法宝。今天&#xff0c;就给大家送上这份超实用的新手实操教程&…

使用DeepSeek协助恢复历史数据

最近&#xff0c;工作中遇到比较老的数据库备份文件数据恢复的问题。过程中使用DeepSeek分析&#xff0c;很快的解决了从除备份文件本身其他信息一概不知的条件下&#xff0c;数据库选型问题和环境搭建问题。下面把实施过程分享出来&#xff0c;给其他遇到相同问题的小伙伴提供…

【特殊场景应对6】频繁跳槽:行业特性与稳定性危机的解释边界

写在最前 作为一个中古程序猿,我有很多自己想做的事情,比如埋头苦干手搓一个低代码数据库设计平台(目前只针对写java的朋友),比如很喜欢帮身边的朋友看看简历,讲讲面试技巧,毕竟工作这么多年,也做到过高管,有很多面人经历,意见还算有用,大家基本都能拿到想要的offe…

企业智能化第一步:用「Deepseek+自动化」打造企业资源管理的智能中枢

随着Deepseek乃至AI人工智能技术在企业中得到了广泛的关注和使用&#xff0c;多数企业开始了AI探索之旅&#xff0c;迅易科技也不例外&#xff0c;且在不断地实践中强化了AI智能应用创新的强大能力。 为解决企业知识管理碎片化、提高内部工作效率等问题&#xff0c;迅易将目光放…

大连理工大学选修课——图形学:第三四章 基本图形生成算法

第三四章 基本图形生成算法 图形生成 概念&#xff1a;如何在指定的输出设备上&#xff0c;根据坐标描述&#xff0c;构造基本二维几何图形 基本二维几何图形&#xff1a;点、直线、圆、多边形域、字符串及相关属性等。 图形生成的概念 是在指定的输出设备上&#xff0c;根…

怎样避免住宅IP被平台识别

要有效避免住宅IP被平台识别&#xff0c;需从IP质量选择、环境参数伪装、行为模式模拟、技术细节处理等多维度构建防御体系。以下是基于行业实践的综合性解决方案&#xff1a; 一、确保住宅IP的高纯净度 选择真实家庭网络IP 验证IP是否归属真实家庭宽带&#xff08;非机房IP伪装…

WPF 触发器 Trigger

触发器 Trigger 触发器&#xff08;Trigger&#xff09;是 WPF 中的一种机制&#xff1a; 当某个条件满足时&#xff0c;自动改变控件的某些属性&#xff0c;比如颜色、大小、透明度等。 换句话说&#xff0c;就是"如果……那么就……" 的一种规则。 常见触发器类…

NLP核心技术解析:大模型与分词工具的协同工作原理

文章目录 一、核心关系概述二、分词工具的核心作用三、未登录词&#xff08;OOV&#xff09;问题3.1 问题本质分析3.2 解决方案3.2.1 预对齐词汇表&#xff08;最优解&#xff09;3.2.2 子词回退策略3.2.3 词汇表扩展&#xff08;适合专业领域&#xff09; 3.3 技术选型建议3.4…

vscode预览模式(点击文件时默认覆盖当前标签,标签名称显示为斜体,可通过双击该标签取消)覆盖标签、新窗打开

文章目录 VS Code 预览模式如何取消预览模式&#xff08;即“固定”标签页&#xff09;&#xff1f;预览模式有什么用&#xff1f; VS Code 预览模式 在 VS Code 中&#xff0c;当你单击文件浏览器&#xff08;例如&#xff0c;资源管理器侧边栏&#xff09;中的某个文件时&am…