[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.pswp.cn/diannao/82124.shtml
繁體地址,請注明出處:http://hk.pswp.cn/diannao/82124.shtml
英文地址,請注明出處:http://en.pswp.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…