LeetCode 算法:路徑總和 III c++

原題鏈接🔗:路徑總和 III
難度:中等????

題目

給定一個二叉樹的根節點 root ,和一個整數 targetSum ,求該二叉樹里節點值之和等于 targetSum路徑 的數目。

路徑 不需要從根節點開始,也不需要在葉子節點結束,但是路徑方向必須是向下的(只能從父節點到子節點)。

示例 1
在這里插入圖片描述

輸入:root = [10,5,-3,3,2,null,11,3,-2,null,1], targetSum = 8
輸出:3
解釋:和等于 8 的路徑有 3 條,如圖所示。

示例 2

輸入:root = [5,4,8,11,null,13,4,7,2,null,null,5,1], targetSum = 22
輸出:3

提示:

  • 二叉樹的節點個數的范圍是 [0,1000]
  • -109 <= Node.val <= 109
  • -1000 <= targetSum <= 1000

題解

什么是深度優先搜索

深度優先搜索(Depth-First Search,簡稱 DFS)是一種用于遍歷或搜索樹或圖的算法。這種算法會盡可能深地搜索樹的分支,當節點 v 的所有可達的鄰接節點都已被探索過,搜索回溯到發現節點 v 的那條邊的起始節點,繼續進行搜索。

深度優先搜索的基本思想是:

  1. 從起始節點開始:選擇一個起始節點,將其標記為已訪問。

  2. 訪問鄰接節點:從當前節點開始,選擇一個未被訪問的鄰接節點,移動到該節點,并將該節點標記為已訪問。

  3. 遞歸搜索:對新到達的節點,重復步驟2,直到找到一個沒有未訪問鄰接節點的節點。

  4. 回溯:當當前節點的所有鄰接節點都被訪問過,或者沒有更多的鄰接節點時,回溯到前一個節點,繼續搜索。

  5. 終止條件:當所有節點都被訪問過,或者搜索完所有可能的路徑時,搜索結束。

深度優先搜索可以用于多種場景,包括但不限于:

  • 連通性問題:確定圖中的節點是否全部連通。
  • 拓撲排序:對有向無環圖(DAG)的頂點進行排序。
  • 路徑查找:在圖中查找從一個節點到另一個節點的路徑。
  • 解決數獨:通過嘗試不同的數字來解決數獨問題。

深度優先搜索通常使用遞歸或顯式的棧來實現。在樹結構中,深度優先搜索可以確保每個節點只被訪問一次,而在圖中,為了避免重復訪問節點,通常需要使用一個集合或數組來跟蹤已訪問的節點。

深度優先搜索的效率取決于圖或樹的結構,以及搜索的具體目標。在最壞的情況下,它可能需要檢查所有可能的節點和邊。

深度優先搜索法

  1. 解題思路

LeetCode 上的 “路徑總和 III” 可以通過深度優先搜索(DFS)來解決。以下是使用 DFS 解決這個問題的步驟:

  • 定義遞歸函數:創建一個遞歸函數,該函數接收當前節點、當前路徑和以及目標和。

  • 初始化路徑和:在遞歸函數中,更新當前路徑和,即從根節點到當前節點的和。

  • 檢查當前節點:如果當前節點是葉子節點(即沒有左右子節點),檢查當前路徑和是否等于目標和。如果是,增加路徑計數。

  • 遞歸遍歷子樹:對當前節點的左右子節點進行遞歸調用,更新路徑和并傳遞給子樹。

  • 回溯:在遞歸調用結束后,需要回溯以撤銷當前節點的選擇,這通常通過減少當前路徑和來實現。

  • 路徑計數:在遞歸過程中,除了檢查當前路徑和是否等于目標和外,還需要將當前路徑和與目標和做差,然后檢查差值是否存在于一個哈希表中,這個哈希表用于存儲從根到當前節點的路徑和。

  • 使用哈希表優化:在遞歸過程中,如果當前節點的路徑和減去目標和的結果存在于哈希表中,那么從當前節點到葉子節點的路徑中,存在一條路徑的和等于目標和。

  • 返回結果:在遞歸的底部,返回路徑計數。

  1. 復雜度:時間復雜度O(N2),空間復雜度O(N)。

  2. c++ demo

#include <iostream>
#include <unordered_map>using namespace std;// 定義二叉樹的節點結構
struct TreeNode {int val;TreeNode* left;TreeNode* right;TreeNode(int x) : val(x), left(nullptr), right(nullptr) {}
};class Solution {
public:int rootSum(TreeNode* root, int targetSum) {if (!root) {return 0;}int ret = 0;if (root->val == targetSum) {ret++;}ret += rootSum(root->left, targetSum - root->val);ret += rootSum(root->right, targetSum - root->val);return ret;}int pathSum(TreeNode* root, int targetSum) {if (!root) {return 0;}int ret = rootSum(root, targetSum);ret += pathSum(root->left, targetSum);ret += pathSum(root->right, targetSum);return ret;}
};int main() {// 構建一個簡單的二叉樹TreeNode* root = new TreeNode(10);root->left = new TreeNode(5);root->right = new TreeNode(-3);root->left->left = new TreeNode(3);root->left->right = new TreeNode(2);root->right->right = new TreeNode(11);root->left->right->right = new TreeNode(1);root->left->left->left= new TreeNode(3);root->left->left->right = new TreeNode(-2);// 創建 Solution 對象Solution solution;int result = solution.pathSum(root, 8); // 尋找路徑和為8的路徑數量cout << "Number of paths with sum 8: " << result << endl;// 釋放二叉樹占用的內存delete root->left->left->right;delete root->left->left->left;delete root->left->right->right;delete root->left->left;delete root->left->right;delete root->right->right;delete root->left;delete root->right;delete root;return 0;
}
  • 輸出結果:

Number of paths with sum 8: 3

  1. 代碼倉庫地址:rootSum

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

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

相關文章

操作系統調度算法、頁面置換算法總結

常見的進程調度算法 FCFS:非搶占、先來先服務。 對短進程不利。 優先級調度算法:在支持搶占的系統中,當新進程進入就緒隊列時,如果它的優先級高于當前運行進程的優先級,那么就會搶占CPU;在非搶占系統中,只是將新進程加入了就緒隊列中。 最短作業優先調度算法(SJF) …

去中心化經濟的革新:探索Web3的新商業模式

隨著區塊鏈技術的發展&#xff0c;Web3正逐漸成為全球經濟和商業模式的關鍵詞之一。Web3不僅僅是技術的革新&#xff0c;更是對傳統中心化商業模式的挑戰和重構。本文將深入探討Web3背后的概念、關鍵技術以及其帶來的新商業模式&#xff0c;帶領讀者走進這一新興領域的深度分析…

272. 最長公共上升子序列

Powered by:NEFU AB-IN Link 文章目錄 272. 最長公共上升子序列題意思路代碼 272. 最長公共上升子序列 題意 如題 思路 若按這個思路的話&#xff0c;代碼為 O ( n 3 ) O(n^3) O(n3) for (int i 1; i < n; i ) {for (int j 1; j < n; j ){f[i][j] f[i - 1][j];…

SpringSecurity中文文檔(Servlet Password Storage)

存儲機制&#xff08;Storage Mechanisms&#xff09; 每種支持的讀取用戶名和密碼的機制都可以使用任何支持的存儲機制&#xff1a; Simple Storage with In-Memory AuthenticationRelational Databases with JDBC AuthenticationCustom data stores with UserDetailsServic…

Cube大小與性能的博弈:Kylin查詢性能優化指南

Cube大小與性能的博弈&#xff1a;Kylin查詢性能優化指南 在Apache Kylin的多維數據分析世界中&#xff0c;Cube是核心組件&#xff0c;它直接影響查詢性能和系統資源的使用。理解Cube大小與查詢性能之間的關系對于構建高效的數據分析平臺至關重要。本文將深入探討Kylin中Cube…

FW SystemUI Keyguard解析(二)

文章目錄 CTS之Keyguard Menu事件處理 CTS之Keyguard Menu事件處理 事件觸發點: NotificationShadeWindowViewController.dispatchKeyEvent 設置setInteractionEventHandler回調之后通過NotificationShadeWindowView 觸發 調用到return mService.onMenuPressed(); public cla…

31-Pandas index操作索引

Pandas index操作索引 索引&#xff08;index&#xff09;是 Pandas 的重要工具&#xff0c;通過索引可以從 DataFame 中選擇特定的行數和列數&#xff0c;這種選擇數據的方式稱為“子集選擇”。 在 Pandas 中&#xff0c;索引值也被稱為標簽&#xff08;label&#xff09;&a…

簡單的text/html無法解析解決記錄

簡單的text/html無法解析解決記錄 1. bug發現 我們所有的服務都是微服務&#xff0c;服務間調用都是使用feign接口進行調用&#xff0c;正常調用都沒有問題&#xff0c;但是某一天發現部分從esb服務調用過來到我們本地的服務&#xff0c;本地服務再使用feign接口調用其他微服…

DPO算法推導

DPO 核心思想&#xff1a;直接使用偏好數據進行策略優化&#xff0c;省去 reward 模型策略優化。 技術背景知識&#xff1a; 首先給定prompt x&#xff0c;生成兩個答案 ( y 1 , y 2 ) Π S F T ( y ∣ x ) (y_1,y_2)~\Pi^{SFT}(y|x) (y1?,y2?) ΠSFT(y∣x) &#xff0c;并通…

2. Python+Playwright playwright的API

Playwright支持同步和異步兩種API&#xff0c;使用異步API需要導入asyncio庫&#xff0c;它是一個可以用來實現Python協程的庫&#xff0c;更詳細介紹可參考Python協程 。我們可以根據自己的偏好選擇適合的模式。 同步與異步模式原理 同步操作方式&#xff1a;在代碼執行時&am…

c++的const

const在C中是一個非常重要的關鍵字&#xff0c;用于定義不可變的變量、函數參數、成員函數等。它可以提高代碼的可讀性、安全性&#xff0c;并幫助編譯器進行優化。 定義常量 使用const定義不可變的變量&#xff1a; const int MAX_SIZE 100;常量指針 指向常量的指針和常量…

【ARMv8/v9 GIC 系列 5 -- GIC GICD_CTRL 使用詳細介紹】

文章目錄 GICD_CTRLGICD_CTLR 寄存器結構RWP&#xff08;Register Write Pending&#xff09;E1NWF&#xff08;Enable 1 of N Wakeup Functionality&#xff09;DS&#xff08;Disable Security&#xff09; 親和性路由&#xff08;Affinity Routing&#xff09;ARE_NSARE_S 中…

【java計算機畢設】服裝生產管理系統java MySQL springboot vue html maven項目設計源代碼+萬字文檔

目錄 1項目功能 2項目介紹 3項目地址 1項目功能 【java計算機畢設】服裝生產管理系統java MySQL springboot vue html maven項目代碼文檔 2項目介紹 系統功能&#xff1a; 服裝生產管理系統包括管理員、用戶兩種角色。 管理員功能包括個人中心模塊用于修改個人信息和密碼&a…

【UE5.3】筆記6-創建可自由控制Pawn類

搭建場景 搭建一個場景&#xff1a;包含地板、圍墻。可以根據喜好加一些自發光的效果。 增加食物 創建食物藍圖類&#xff0c;在場景里放置一些食物以供我們player去吃掉獲取分值。 創建可控制的layer 我們先右鍵創建一個藍圖繼承自pawn類&#xff0c;起名BP_Player&#xf…

Python-算法編程100例-二分法(入門級)-業務負載分配

題目&#xff1a; 現有一個服務器集群&#xff08;服務器數量為 serverNum&#xff09;&#xff0c;和一批不同類型的任務&#xff08;用數組 tasks 表示&#xff0c;下標表示任務類型&#xff0c;值為任務數量&#xff09;。 現需要把這批任務都分配到集群的服務器上&#x…

2024年在WordPress中創建銷售活動的專家級優惠券方法

2024年在WordPress中創建銷售活動的專家級優惠券方法 今天我想和大家分享一些關于如何在WordPress網站上使用專家級優惠券工具來創建銷售活動的經驗。對于已經在電商領域有一定經驗的店主&#xff0c;利用專家級優惠券不僅能吸引顧客&#xff0c;還能顯著增加銷量。在這篇文章…

【Linux】線程封裝與互斥(萬字)

提示&#xff1a;文章寫完后&#xff0c;目錄可以自動生成&#xff0c;如何生成可參考右邊的幫助文檔 目錄 文章目錄 前言 C多線程的用法 對原生線程進行一次封裝 理解pthread線程 Linux線程互斥 進程線程間的互斥相關背景概念 互斥量mutex 操作共享變量會有問題的售票…

[go-zero] goctl 生成api和rpc

文章目錄 1.goctl 概述2.go-zero 需要安裝的組件3.生成 api4.生成 rpc 1.goctl 概述 goctl支持多種rpc&#xff0c;較為流行的是google開源的grpc&#xff0c;這里主要介紹goctl rpc protoc的代碼生成與使用。protoc是grpc的命令&#xff0c;作用是將proto buffer文件轉化為相…

探討命令模式及其應用

目錄 命令模式命令模式結構命令模式適用場景命令模式優缺點練手題目題目描述輸入描述輸出描述題解 命令模式 命令模式是一種行為設計模式&#xff0c; 它可將請求轉換為一個包含與請求相關的所有信息的獨立對象。 該轉換讓你能根據不同的請求將方法參數化、 延遲請求執行或將其…

《亞馬遜搬運亞馬遜產品》配合跟賣采集爬取跟賣店鋪高質量

亞馬遜高質量產品如何搬運&#xff1f;亞馬遜采集亞馬遜。 哈嘍大家好&#xff0c;大家講一下做亞馬遜是發貨、鋪貨這塊的功能。目前這款軟件做跟賣大家都知道&#xff0c;同時也支持做鋪貨。鋪貨可以采集國內的1688、淘寶、京東都可以采&#xff0c;采完之后也可以采速賣通&a…