Leetcode 2065. 最大化一張圖中的路徑價值(DFS / 最短路)

Leetcode 2065. 最大化一張圖中的路徑價值

暴力DFS

容易想到,從0點出發DFS,期間維護已經走過的距離(時間)和途徑點的權值之和,若訪問到0點則更新答案,若下一步的距離與已走過的距離和超出了maxTime,則不能向下繼續DFS

注意的是,每個點的權值只會計算一次,可以使用一個boolean數組 vis[ ] 來記錄該點的權值是否已經計算過
另一種方法是,每當第一次到達一個點并獲得權值后,將它的權值修改為0,若后續又一次訪問到該點,加0不會影響最終結果,省去vis數組的操作

超時,通過樣例59 / 62

class Solution {int res;public void dfs(int x, int[] values, int[][] map, int maxTime, int time, int sum){if(x == 0){res = Math.max(res, sum);}int n = values.length;for(int i = 0 ; i < n; i ++){if(map[x][i] != 0 && time + map[x][i] <= maxTime){int val = values[i];values[i] = 0;dfs(i, values, map, maxTime, time + map[x][i], sum + val);values[i] = val;}}return ;}public int maximalPathQuality(int[] values, int[][] edges, int maxTime) {int n = values.length;int [][] map = new int [n][n];for(int[] e: edges){int a = e[0];int b = e[1];int t = e[2];map[a][b] = t;map[b][a] = t;}res = 0;int val = values[0];values[0] = 0;dfs(0, values, map, maxTime, 0, val);return res;}
}

最短路 優化剪枝

注意到,當判斷一個點是否可以繼續深入時,可以考慮的一種剪枝方式是,向該點前進后,若剩余的時間不足以返回0點,則不必向該點DFS
該問題轉換為,判斷x點回到0點的距離是否超過maxTime - time,即為0點出發的最短路問題,使用Dijstra算法實現

另一方面,當圖中的點較稀疏時,使用鄰接矩陣遍歷找邊會導致時間的浪費,因此選擇使用鄰接表實現圖的存儲

class Solution {int res;public void dfs(int x, int[] values, List<int[]>[] map, int maxTime, int time, int sum, int[] dis){if(x == 0){res = Math.max(res, sum);}int n = values.length;for(int arr[] : map[x]){int y = arr[0];int t = arr[1];// 求和時增加dis,若不足返回0點則不必DFSif(time + t + dis[y] <= maxTime){int val = values[y];values[y] = 0;dfs(y, values, map, maxTime, time + t, sum + val, dis);values[y] = val;}}return ;}public int maximalPathQuality(int[] values, int[][] edges, int maxTime) {int n = values.length;// 鄰接表  map[x]為x發出的邊的集合List,List中的每個int[],int[0]為終點,int[1]為距離List<int[]>[] map = new ArrayList[n];for(int i = 0 ; i < n; i ++){map[i] = new ArrayList<int[]>();}for(int[] e: edges){int a = e[0];int b = e[1];int t = e[2];map[a].add(new int[]{b, t});map[b].add(new int[]{a, t});}// dijstraint inf = Integer.MAX_VALUE;int dis[] = new int [n];Arrays.fill(dis, inf);for(int [] arr: map[0]){int y = arr[0];int t = arr[1];dis[y] = t;}boolean vis[] = new boolean[n];vis[0] = true;while(true){int min = Integer.MAX_VALUE;int index = -1;for(int i = 0 ; i < n; i ++){if(!vis[i] && dis[i] < min){min = dis[i];index = i;}}if(index == -1)break;vis[index] = true;// 遍歷index點發出的邊for (int[] arr : map[index]) {int v = arr[0];int t = arr[1];if (!vis[v] && dis[index] + t < dis[v]) {dis[v] = dis[index] + t;}}}// DFSres = 0;int val = values[0];values[0] = 0;dfs(0, values, map, maxTime, 0, val, dis);return res;}
}

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/diannao/38880.shtml
繁體地址,請注明出處:http://hk.pswp.cn/diannao/38880.shtml
英文地址,請注明出處:http://en.pswp.cn/diannao/38880.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

oracle sql語句 排序 fjd = ‘0101‘ 排在 fjd = ‘0103‘ 的前面

要實現這個排序需求&#xff0c;你可以使用 CASE 表達式來自定義排序邏輯。假設你有一個表格名為 your_table&#xff0c;并且有一個字段 fjd 存儲類似 ‘0101’, ‘0103’ 這樣的值&#xff0c;你可以這樣編寫 SQL 查詢&#xff1a; SELECT * FROM your_table ORDER BY CASE …

專題六:Spring源碼之初始化容器BeanFactory

上一篇咱們通過一個例子介紹初始化容器上下文相關內容&#xff0c;并通過兩個示例代碼看到了Spring在設計階段為我預留的擴展點&#xff0c;和我們應該如何利用這兩個擴展點在Spring初始化容器上下文階段為我們提供服務。這一篇咱們接著往下看。 老這樣子下回到refresh方法上來…

第55期:MySQL 頻繁 Crash 怎么辦?

社區王牌專欄《一問一實驗&#xff1a;AI 版》全新改版歸來&#xff0c;得到了新老讀者們的關注。其中不乏對 ChatDBA 感興趣的讀者前來咨詢&#xff0c;表達了想試用體驗 ChatDBA 的意愿&#xff0c;對此我們表示感謝 &#x1f91f;。 目前&#xff0c;ChatDBA 還在最后的準備…

MSVCR120.DLL丟失的多種修復方法,助你快速解決dll問題

在日常生活和工作中&#xff0c;電腦已經成為我們不可或缺的工具。然而&#xff0c;在使用電腦的過程中&#xff0c;我們常常會遇到一些問題&#xff0c;其中之一就是電腦運行軟件時提示找不到msvcr120.dll。如果該文件缺失或損壞&#xff0c;可能會導致依賴它的應用程序無法啟…

高優先線程

你開發的時候有么有遇到過一個問題&#xff1a;服務器的一個服務線程過幾個小時斷連一次&#xff0c;斷連之后會馬上重連這種情況。這是由于CPU負載較高,線程調度時將處理數據的線程掛起了一段時間導致的。 因此&#xff0c;我有考慮到把cpu的核心進行分散開來&#xff0c;就類…

CesiumJS【Basic】- #042 繪制紋理線(Primitive方式)

文章目錄 繪制紋理線(Primitive方式)1 目標2 代碼2.1 main.ts3 資源文件繪制紋理線(Primitive方式) 1 目標 使用Primitive方式繪制紋理線 2 代碼 2.1 main.ts var start = Cesium.Cartesian3.fromDegrees(-75.59777, 40.03883);var

【劍指Offer系列】68-二叉樹的最近公共祖先(哈希)

思路&#xff1a;使用map存儲每個節點的父節點&#xff0c;則兩個節點的最近公共祖先&#xff0c;即二者的最近父節點 1、中序遍歷二叉樹&#xff08;當前節點的下一個節點&#xff09; 2、記錄每個節點的父節點 3、列出p的族譜、q的族譜 4、尋找二者最近的祖先 class Soluti…

微信小程序畢業設計-英語互助系統項目開發實戰(附源碼+論文)

大家好&#xff01;我是程序猿老A&#xff0c;感謝您閱讀本文&#xff0c;歡迎一鍵三連哦。 &#x1f49e;當前專欄&#xff1a;微信小程序畢業設計 精彩專欄推薦&#x1f447;&#x1f3fb;&#x1f447;&#x1f3fb;&#x1f447;&#x1f3fb; &#x1f380; Python畢業設計…

PS系統教程31

調色之色階 調色與通道最基本的關系通道是記錄顏色最基本的信息有些圖片可以用通道去改變顏色信息的說明這些圖像是比較高級的PS是一款圖像合成軟件&#xff0c;在合成過程中需要處理大量素材&#xff0c;比如要用這些素材進行摳背景&#xff0c;就要用到圖層蒙版以及Alpha通道…

Qt編程技巧總結篇(2)-信號-槽-多線程(一)

文章目錄 Qt編程技巧總結篇&#xff08;2&#xff09;-信號-槽-多線程&#xff08;一&#xff09;信號與槽實例與應用 小結 Qt編程技巧總結篇&#xff08;2&#xff09;-信號-槽-多線程&#xff08;一&#xff09; 最近學習信號與槽以及多線程&#xff0c;非常有技術含量&#…

【詳解】RV1106移植opencv-mobile庫

文章目錄 前言一、燒入鏡像二、編譯項目1.創建項目文件 三、移植四、運行文件五、總結 前言 硬件&#xff1a;瑞芯微Rv1106【Luckfox Pro\Max Pico、網線一根、USB線、串口助手、攝像頭 軟件&#xff1a;ubuntu 20.4 編譯器&#xff1a;arm-rockchip830-linux-uclibcgnueabihf…

人工智能——常用數學基礎之線代中的矩陣

1. 矩陣的本質&#xff1a; 矩陣本質上是一種數學結構&#xff0c;它由按照特定規則排列的數字組成&#xff0c;通常被表示為一個二維數組。矩陣可以用于描述一組數據&#xff0c;或者表示某種關系&#xff0c;比如線性變換。 在人工智能中&#xff0c;矩陣常被用來表示數據集…

【單片機與嵌入式】stm32串口通信入門

一、串口通信/協議 &#xff08;一&#xff09;串口通信簡介 串口通信是一種通過串行傳輸方式在電子設備之間進行數據交換的通信方式。它通常涉及兩條線&#xff08;一條用于發送數據&#xff0c;一條用于接收數據&#xff09;&#xff0c;適用于各種設備&#xff0c;從微控制…

Spring中利用重載與靜態分派

Spring中利用重載與靜態分派 在Java和Spring框架中&#xff0c;重載&#xff08;Overloading&#xff09;和靜態分派&#xff08;Static Dispatch&#xff09;是兩個非常重要的概念&#xff0c;它們在處理類方法選擇和執行過程中扮演著關鍵角色。本文旨在深入探討Spring環境下…

入選頂會ICML,清華AIR等聯合發布蛋白質語言模型ESM-AA,超越傳統SOTA

作為細胞內無數生化反應的驅動力&#xff0c;蛋白質在細胞微觀世界中扮演著建筑師和工程師的角色&#xff0c;不僅催化著生命活動&#xff0c;更是構筑、維系生物體形態與功能的基礎構件。正是蛋白質之間的互動、協同作用&#xff0c;支撐起了生命的宏偉藍圖。 然而&#xff0…

Ubuntu DNS服務配置 深度解析

測試方法 resolvectl status dig alidns.com 修改實踐 直接用接口配置&#xff0c;沒用 /etc/resolv.conf&#xff0c;有效 /etc/netplan/01-network-manager-all.yaml,無效 /etc/systemd/resolved.conf&#xff0c;見link&#xff0c;為全局配置 [Resolve] DNS1.1.1.1 Fa…

Adobe Premiere 視頻編輯軟件下載安裝,pr全系列分享 輕松編輯視頻

Adobe Premiere&#xff0c;自其誕生之日起&#xff0c;便以其卓越的性能和出色的表現&#xff0c;穩坐視頻編輯領域的王者寶座&#xff0c;贏得了無數專業編輯人員與廣大愛好者的青睞。這款強大的視頻編輯軟件&#xff0c;憑借其豐富的功能和靈活的操作性&#xff0c;為用戶提…

2024年道路運輸安全員(企業管理人員)備考題庫資料。

46.危險貨物道路運輸隨車攜帶的單據&#xff0c;下列選項不屬于的是&#xff08;&#xff09;。 A.道路運輸危險貨物安全卡 B.運單或者電子運單 C.道路危險貨物運輸從業資格證 D.車輛檢測報告 答案&#xff1a;D 47.危險貨物運輸駕駛人員在24小時內實際駕駛車輛時間累計不…

ROS2在rviz2中實時顯示軌跡和點

本文是將《ROS在rviz中實時顯示軌跡和點》博客中rviz軌跡顯示轉為ROS2環境中的rviz2顯示。 ros2的工作空間創建這里就不展示了。 包的創建 ros2 pkg create --build-type ament_cmake showpath --dependencies rclcpp nav_msgs geometry_msgs tf2_geometry_msgsshowpath.cpp…

Windows批處理入門:快速掌握批處理腳本的基本技巧

一、前言 在Windows操作系統中&#xff0c;批處理文件&#xff08;Batch File&#xff09;是一種非常實用的工具&#xff0c;它允許用戶通過簡單的命令行腳本來自動化各種任務。無論是系統管理員、開發人員&#xff0c;還是普通用戶&#xff0c;掌握批處理文件的基本知識都能極…