LeetCode算法題(Go語言實現)_37

題目

給你一棵以 root 為根的二叉樹,二叉樹中的交錯路徑定義如下:
選擇二叉樹中 任意 節點和一個方向(左或者右)。
如果前進方向為右,那么移動到當前節點的的右子節點,否則移動到它的左子節點。
改變前進方向:左變右或者右變左。
重復第二步和第三步,直到你在樹中無法繼續移動。
交錯路徑的長度定義為:訪問過的節點數目 - 1(單個節點的路徑長度為 0 )。
請你返回給定樹中最長 交錯路徑 的長度。

一、代碼實現

func longestZigZag(root *TreeNode) int {maxLen := 0var dfs func(*TreeNode) (int, int)dfs = func(node *TreeNode) (int, int) {if node == nil {return 0, 0}_, leftRight := dfs(node.Left)rightLeft, _ := dfs(node.Right)currentLeft, currentRight := 0, 0if node.Left != nil {currentLeft = leftRight + 1}if node.Right != nil {currentRight = rightLeft + 1}if currentLeft > maxLen {maxLen = currentLeft}if currentRight > maxLen {maxLen = currentRight}return currentLeft, currentRight}dfs(root)return maxLen
}

二、算法分析

1. 核心思路
  • 動態規劃(后序遍歷):每個節點維護兩個狀態,表示從該節點出發下一步向左或向右的最長交錯路徑長度。
  • 狀態轉移:當前節點的左方向長度由左子節點的右方向長度加1,右方向長度由右子節點的左方向長度加1。
  • 全局最大值:在遍歷過程中不斷更新最長路徑長度。
2. 關鍵步驟
  1. 遞歸終止:空節點返回 (0, 0)
  2. 狀態計算:根據左右子節點返回的狀態計算當前節點的左右方向長度。
  3. 更新最大值:比較并更新全局最長路徑長度。
  4. 返回狀態:返回當前節點的左右方向長度供父節點使用。
3. 復雜度
指標說明
時間復雜度O(n)每個節點遍歷一次
空間復雜度O(h)遞歸棧空間,h為樹的高度

三、圖解示例

在這里插入圖片描述

四、邊界條件與擴展

1. 特殊場景驗證
  • 單節點樹:直接返回0。
  • 完全左斜樹:所有節點只有左子節點,最長路徑為1。
  • 交替路徑:如 1→2→3→4→5,路徑長度為4。
2. 多語言實現
class TreeNode:def __init__(self, val=0, left=None, right=None):self.val = valself.left = leftself.right = rightclass Solution:def longestZigZag(self, root: TreeNode) -> int:self.max_len = 0def dfs(node):if not node:return (0, 0)left_left, left_right = dfs(node.left)right_left, right_right = dfs(node.right)current_left = left_right + 1 if node.left else 0current_right = right_left + 1 if node.right else 0self.max_len = max(self.max_len, current_left, current_right)return (current_left, current_right)dfs(root)return self.max_len
class TreeNode {int val;TreeNode left;TreeNode right;TreeNode(int x) { val = x; }
}class Solution {private int maxLen = 0;public int longestZigZag(TreeNode root) {dfs(root);return maxLen;}private int[] dfs(TreeNode node) {if (node == null) return new int[]{0, 0};int[] left = dfs(node.left);int[] right = dfs(node.right);int currentLeft = node.left != null ? left[1] + 1 : 0;int currentRight = node.right != null ? right[0] + 1 : 0;maxLen = Math.max(maxLen, Math.max(currentLeft, currentRight));return new int[]{currentLeft, currentRight};}
}

五、總結與擴展

1. 核心創新點
  • 狀態定義:通過左右方向狀態分離,避免路徑方向沖突。
  • 后序遍歷:自底向上遞推,確保子問題先解。
2. 擴展應用
  • 多方向路徑:擴展到多叉樹,增加狀態維度。
  • 加權路徑:節點帶權重,求最大權重路徑。
  • 實時更新:處理動態樹結構,增量維護狀態。
3. 工程優化
  • 迭代實現:用棧模擬遞歸,減少函數調用開銷。
  • 并行處理:對子樹進行并行計算,提升大規模數據處理效率。

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

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

相關文章

博途 TIA Portal之1200做從站與匯川EASY的TCP通訊

上篇我們寫到了博途做主站與匯川EASY的通訊。通訊操作起來很簡單,當然所謂的簡單,也是相對的,如果操作成功一次,那么后面就很容易了, 如果操作不成功,就會很遭心。本篇我們將1200做從站,與匯川EASY做主站進行TCP的通訊。 1、硬件準備 1200PLC一臺,帶調試助手的PC機一…

Mysql(繼續更新)

INnoDB 三特性 事務 外鍵 行級鎖(開啟事務時,查詢后加FOR UPDATE) MySQL 使用 InnoDB,在 默認隔離級別 —— REPEATABLE READ(可重復讀) 下 開啟事務,執行 UPDATE 時默認會加行鎖 只要事務沒有提交 這條數據會鎖住 …

[IOI 1994] 數字三角形 Number Triangles

題目鏈接 思路(上到下): ①從上往下遞推: f[i][j] max(f[i-1][j] g[i][j], f[i-1][j-1]g[i][j]) ②對最后一層,遍歷一下,找到最大的答案。 代碼(上到下): #inclu…

基于Qt的串口通信工具

程序介紹 該程序是一個基于Qt的串口通信工具,專用于ESP8266 WiFi模塊的AT指令配置與調試。主要功能包括: 1. 核心功能 串口通信:支持串口開關、參數配置(波特率、數據位、停止位、校驗位)及數據收發。 AT指令操作&a…

第5篇:Linux程序訪問控制FPGA端LEDR<三>

Q:如何具體設計.c程序代碼訪問控制FPGA端外設? A:以控制DE1-SoC開發板的LEDR為例的Linux .C程序代碼。頭文件fcntl.h和sys/mman.h用于使用/dev/mem文件,以及mmap和munmap內核函數;address_map_arm.h指定了DE1-SoC_Com…

【學生管理系統升級版】

學生管理系統升級版 需求分析:注冊功能:登錄功能:驗證碼規則:忘記密碼: 實操:系統主頁面注冊功能登錄功能忘記密碼效果演示 需求 為學生管理系統書寫一個登陸、注冊、忘記密碼的功能。 ? ? 只有用戶登錄成功之后&…

CSS Grid布局:從入門到放棄再到真香

Flexbox 與 Grid 布局:基礎概念與特點 Flexbox Flexbox(Flexible Box Layout),即彈性盒布局模型,主要用于創建一維布局,能夠輕松實現元素在一行或一列中的排列、對齊與分布。通過display: flex屬性啟用 Fl…

C++怎么調用類中的函數

1. 棧上對象 調用普通成員方法 普通成員方法需要通過類的對象實例&#xff08;或指針、引用&#xff09;來調用。 示例&#xff1a; class MyClass { public:void normalMethod() {std::cout << "普通成員方法被調用" << std::endl;} };int main() {M…

go游戲后端開發31:麻將游戲的碰牌與胡牌邏輯

以下是潤色后的版本&#xff1a; 1. 碰牌邏輯 1.1 觸發碰牌 當一個玩家棄牌后&#xff0c;其他玩家可以選擇碰牌。如果當前玩家決定碰牌&#xff0c;系統需要通知所有玩家這一操作。碰牌操作完成后&#xff0c;當前玩家需要出一張牌&#xff0c;系統同樣需要通知所有玩家。 …

十分鐘機器學習之--------------線性回歸

線性回歸&#xff08;linear regression&#xff09;是一種基于數學模型的算法&#xff0c;首先假設數據集與標簽之間存在線性關系&#xff0c;然后簡歷線性模型求解參數。在實際生活中&#xff0c;線性回歸算法因為其簡單容易計算&#xff0c;在統計學經濟學等領域都有廣泛的應…

學透Spring Boot — 017. 處理靜態文件

這是我的《學透Spring Boot》專欄的第17篇文章&#xff0c;了解更多內容請移步我的專欄&#xff1a; Postnull CSDN 學透 Spring Boot 目錄 靜態文件 靜態文件的默認位置 通過配置文件配置路徑 通過代碼配置路徑 靜態文件的自動配置 總結 靜態文件 以前的傳統MVC的項目…

深入理解 JavaScript 數組查找:如何高效獲取特定元素

深入理解 JavaScript 數組查找&#xff1a;如何高效獲取特定元素 深入理解 JavaScript 數組查找&#xff1a;如何高效獲取特定元素引言問題場景解決方案1. 使用 Array.prototype.find()2. 處理 Proxy 對象的情況3. 備選方案&#xff1a;Array.prototype.filter()4. 傳統 for 循…

HTML5+CSS3小實例:純CSS繪制七巧板

實例:純CSS繪制七巧板 技術棧:HTML+CSS 效果: 源碼: 【HTML】 <!DOCTYPE html> <html lang="zh-CN"> <head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale…

[electron]自動注冊IPC的解決方案

前言 主進程和渲染進程通過IPC進行通信&#xff0c;每次需要定義名稱并注冊&#xff0c;很多代碼都是重復書寫&#xff0c;并且如果主進程和渲染進程開發人員是同一個的話&#xff0c;很多東西都可以簡化。 渲染進程通過ipcRenderer.invoke與主進程通信&#xff0c;主進程通過i…

JS—防抖和節流:1分鐘掌握防抖和節流

個人博客&#xff1a;haichenyi.com。感謝關注 一. 目錄 一–目錄二–防抖三–節流四–進階應用五–總結 二. 防抖&#xff08;Debounce&#xff09; 防抖&#xff08;Debebounce&#xff09;和節流&#xff08;Throttle&#xff09;都是前端開發中用于優化高頻事件性能的兩…

測試模板1

本篇技術博文摘要 &#x1f31f; 引言 &#x1f4d8; 在這個變幻莫測、快速發展的技術時代&#xff0c;與時俱進是每個IT工程師的必修課。我是盛透側視攻城獅&#xff0c;一名什么都會一丟丟的網絡安全工程師&#xff0c;也是眾多技術社區的活躍成員以及多家大廠官方認可人員&a…

Nginx配置Http響應頭安全策略,未設置X-Content-Type-Options響應頭【原理掃描】

文章目錄 前言一、漏洞掃描問題二、漏洞描述三、解決方法3.1、Nginx配置概覽3.2、注意事項 四、感謝 前言 第三方安全檢測機構甩過來一篇漏洞掃描報告&#xff0c;需要我們整改。 一、漏洞掃描問題 漏洞掃描問題如下&#xff1a; 未設置X-Content-Type-Options響應頭【原理掃…

Gerapy二次開發:用戶管理專欄新增與編輯頁面開發

用戶管理專欄新增與編輯頁面開發 寫在前面Vue表單設計與開發Vue的this.$refs功能實現前端Create.vueEdit.vueSubstance.vue效果預覽后端urls.pyviews.py整體效果預覽新增編輯總結歡迎加入Gerapy二次開發教程專欄! 本專欄專為新手開發者精心策劃了一系列內容,旨在引領你深入探…

HOW - 實現 useClickOutside 或者 useClickAway

場景 在開發過程中經常遇到需要點擊除某div范圍之外的區域觸發回調&#xff1a;比如點擊 dialog 外部區域關閉。 手動實現 import { useEffect } from "react"/*** A custom hook to detect clicks outside a specified element.* param ref - A React ref object…

SpringBoot整合sa-token,Redis:解決重啟項目丟失登錄態問題

SpringBoot整合sa-token&#xff0c;Redis&#xff1a;解決重啟項目丟失登錄態問題 &#x1f525;1. 痛點直擊&#xff1a;為什么登錄狀態會消失&#xff1f;2.實現方案2.1.導入依賴2.2.新增yml配置文件 3.效果圖4.結語 &#x1f600;大家好&#xff01;我是向陽&#x1f31e;&…