LeetCode題練習與總結:從前序與中序遍歷序列構造二叉樹--105

一、題目描述

給定兩個整數數組?preorderinorder?,其中?preorder 是二叉樹的先序遍歷inorder?是同一棵樹的中序遍歷,請構造二叉樹并返回其根節點。

示例 1:

輸入: preorder = [3,9,20,15,7], inorder = [9,3,15,20,7]
輸出: [3,9,20,null,null,15,7]

示例 2:

輸入: preorder = [-1], inorder = [-1]
輸出: [-1]

提示:

  • 1 <= preorder.length <= 3000
  • inorder.length == preorder.length
  • -3000 <= preorder[i], inorder[i] <= 3000
  • preorder?和?inorder?均 無重復 元素
  • inorder?均出現在?preorder
  • preorder?保證 為二叉樹的前序遍歷序列
  • inorder?保證 為二叉樹的中序遍歷序列

二、解題思路

?這個問題是關于如何根據給定的先序遍歷和中序遍歷數組來重建二叉樹。我們可以使用遞歸方法來解決這個問題。

算法步驟:

  1. 首先,在先序遍歷數組preorder中找到根節點的值。
  2. 然后,在inorder數組中找到根節點的值,并以此為界將inorder數組分為左右兩部分。
  3. 遞歸地構造左子樹和右子樹。
  4. 左子樹的preorder數組為preorder數組中根節點后面的所有值,左子樹的inorder數組為inorder數組中左子樹部分的所有值。
  5. 右子樹的preorder數組為preorder數組中根節點后面的所有值,右子樹的inorder數組為inorder數組中右子樹部分的所有值。
  6. 重復上述步驟,直到所有節點都被處理。

三、具體代碼

class Solution {public TreeNode buildTree(int[] preorder, int[] inorder) {if (preorder == null || inorder == null) {return null;}return helper(preorder, 0, preorder.length - 1, inorder, 0, inorder.length - 1);}private TreeNode helper(int[] preorder, int preorderStart, int preorderEnd, int[] inorder, int inorderStart, int inorderEnd) {if (preorderStart > preorderEnd || inorderStart > inorderEnd) {return null;}int rootVal = preorder[preorderStart];TreeNode root = new TreeNode(rootVal);int index = inorderStart;while (index <= inorderEnd && inorder[index] != rootVal) {index++;}int leftSubtreeSize = index - inorderStart;int rightSubtreeSize = inorderEnd - index;root.left = helper(preorder, preorderStart + 1, preorderStart + leftSubtreeSize, inorder, inorderStart, index - 1);root.right = helper(preorder, preorderStart + leftSubtreeSize + 1, preorderEnd, inorder, index + 1, inorderEnd);return root;}
}

四、時間復雜度和空間復雜度

1. 時間復雜度
  • helper?函數對于每個節點都會被調用一次,其中?n?是樹中節點的數量。
  • 在?helper?函數內部,對于每個節點,我們都會進行一次數組查找(index?循環),這需要 O(1) 的時間。
  • 因此,總的時間復雜度是 O(n)。
2. 空間復雜度
  • 空間復雜度主要取決于遞歸調用棧的深度,這通常與樹的高度?h?有關。
  • 在最壞的情況下,樹是完全不平衡的,例如每個節點都只有左子節點或者只有右子節點,此時樹的高度等于節點的數量,空間復雜度為 O(n)。
  • 在最好的情況下,樹是完全平衡的,此時樹的高度為?log(n),空間復雜度為 O(log(n))。
  • 因此,空間復雜度在 O(log(n)) 到 O(n) 之間,取決于樹的形狀。

綜上所述,代碼的時間復雜度是 O(n),空間復雜度在 O(log(n)) 到 O(n) 之間,取決于樹的形狀。

五、總結知識點

  1. 遞歸:代碼使用了遞歸的方法來構建二叉樹。遞歸是一種分而治之的算法技巧,將復雜問題分解為更小的子問題,并逐個解決。

  2. 二叉樹:代碼操作的是二叉樹數據結構,這是一種每個節點最多有兩個子節點的樹形結構。

  3. 先序遍歷和中序遍歷:先序遍歷是指根節點、左子樹、右子樹的順序,中序遍歷是指左子樹、根節點、右子樹的順序。這兩個遍歷順序是構建二叉樹的關鍵信息來源。

  4. 數組操作:代碼中使用了數組操作來找到根節點在先序和中序遍歷中的位置,并以此構建左右子樹。

  5. 函數返回值buildTree?函數返回構建的二叉樹的根節點,而?helper?函數返回當前節點的子節點。

  6. 節點定義:代碼中使用了?TreeNode?類來定義二叉樹的節點,每個節點包含一個整數值和指向左右子節點的引用。

  7. 遞歸的基本情況:遞歸函數通常有一個基本情況(base case),即遞歸退出的條件。在這個問題中,基本情況是當?preorderStart > preorderEnd?或?inorderStart > inorderEnd?時,表示沒有更多的節點可以處理,此時返回?null

  8. 類型轉換:在遞歸調用中,buildTree?函數的返回值被隱式轉換為?TreeNode?類型。

  9. 遞歸調用棧:遞歸函數的調用會形成調用棧,用于存儲每一層遞歸調用的局部變量和返回地址。

  10. 樹的高度與深度:在二叉樹中,根節點的深度為1,每個子節點的深度是其父節點深度加1。樹的高度是從根節點到最遠葉子節點的最長路徑上的節點數。

以上就是解決這個問題的詳細步驟,希望能夠為各位提供啟發和幫助。

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

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

相關文章

什么是經典藍牙模塊?

什么是經典藍牙模塊&#xff1f;   前面我們已經就藍牙模塊的概念做了了解&#xff0c;隨著時間的推移&#xff0c;產品越來越智能&#xff0c;需要的藍牙模塊也就越來越廣泛&#xff0c;本篇文章我們就一起了解下什么是經典藍牙模塊。   經典藍牙模塊(BT)泛指支持藍牙協議…

SwiftUI中的手勢(DragGesture拖拽手勢及Drag動畫組件)

上一篇文章我們了解了如何使用.gesture修飾符和GestureState屬性包裝器&#xff0c;讓我們看看另一種常見的手勢&#xff1a;DragGesture拖拽手勢。 下面先看個效果圖&#xff1a; 這個效果中&#xff0c;我們實現了一個Text文本&#xff0c;并添加了拖拽手勢&#xff0c;可以…

代碼隨想錄算法訓練營第三十八天| 435. 無重疊區間 、763.劃分字母區間、56. 合并區間

435. 無重疊區間 題目鏈接&#xff1a;435. 無重疊區間 文檔講解&#xff1a;代碼隨想錄/無重疊區間 視頻講解&#xff1a;視頻講解-無重疊區間 狀態&#xff1a;已完成&#xff08;1遍&#xff09; 解題過程 看到題目的第一想法 這道題我的想法是首先將集合按照start從小到…

看上去好坑的運算符重載

#include <iostream> using namespace std; class MyInt {int nVal; public:MyInt(int n) { nVal n};MyInt & operator-(int n){ //運算符重載-nVal - n;return *this; } operator int() {return nVal;} //類型轉換函數};int Inc(int n){return n1; }int ma…

代碼隨想錄訓練營|一刷總結

代碼隨想錄一刷完成啦&#xff01;&#xff01;&#xff01; 自己曾經嘗試過刷力扣&#xff0c;但是卻不知道從何刷起、按什么順序刷題&#xff0c;直到遇到了卡哥、遇到了代碼隨想錄。研一上有著刷題的決心&#xff0c;但是卻沒有刷題的動力很難堅持下去&#xff0c;所以也就只…

【削水果game】

編寫一個完整的削水果游戲代碼是一個復雜的過程&#xff0c;涉及到游戲引擎的使用和游戲邏輯的編寫。在這里&#xff0c;我可以提供一個非常簡化的版本&#xff0c;使用Python和Pygame庫來創建一個基本的削水果游戲概念。請注意&#xff0c;這只是一個示例&#xff0c;用于展示…

Flutter Text導致A RenderFlex overflowed by xxx pixels on the right.

使用Row用來展示兩個Text的時候頁面出現如下異常,提示"A RenderFlex overflowed by xxx pixels on the right." The following assertion was thrown during layout: A RenderFlex overflowed by 4.8 pixels on the right.The relevant error-causing widget was:…

【仿RabbitMQ消息隊列項目day2】使用muduo庫中基于protobuf的應用層協議進行通信

一.什么是muduo? muduo庫是?個基于非阻塞IO和事件驅動的C高并發TCP網絡編程庫。 簡單來理解&#xff0c;它就是對原生的TCP套接字的封裝&#xff0c;是一個比socket編程接口更好用的編程庫。 二.使用muduo庫完成一個英譯漢翻譯服務 TranslateServer.hpp: #pragma once #in…

MyBatis中Where標簽:揭秘高效SQL構建的秘密

哈嘍&#xff0c;大家好&#xff0c;我是木頭左&#xff01; 理解Where標簽的基礎概念 在MyBatis中&#xff0c;<where>標簽是用于構建SQL查詢語句中的一個非常重要的元素。它允許你在一個動態的SQL語句中添加WHERE子句&#xff0c;而不需要擔心SQL語法錯誤或額外的逗號…

如何利用51建模網,實現3D模型線上展示和應用?

按照下面的步驟&#xff0c;在51建模網上傳3D模型&#xff0c;并編輯完成后&#xff0c;接下來就是如何讓這些3D模型得到更好的展示、傳播和應用。 一、3D內容快速分享與傳播 3D模型在51建模網上傳發布后&#xff0c;即可獲得一個可分享的鏈接和二維碼&#xff0c;直接分享給客…

20240520解決在Ubuntu20.04下編譯RK3588的Android12的SDK出現C2_GIT_BUILD_VERSION未定義的問題

20240520解決在Ubuntu20.04下編譯RK3588的Android12的SDK出現C2_GIT_BUILD_VERSION未定義的問題 2024/5/20 20:19 緣起&#xff1a;通過./repo/repo/repo sync -l得到的SDK正常&#xff0c;但是解壓縮之后的SDK卻出錯了&#xff01; 通過grep很容易發現有三個地方有&#xff0c…

深入分析 Android Activity (一)

深入分析 Android Activity (一) 接下來我們會深入分析 Activity 的一些高級特性和內部實現&#xff0c;包括窗口管理、生命周期管理、以及與 Fragment 的交互。 1. Activity 的窗口管理 在 Android 中&#xff0c;每個 Activity 都與一個 Window 相關聯。Window 是一個抽象…

如何選購尼龍輸送帶

尼龍輸送帶選購攻略&#xff1a;從入門到精通&#xff0c;一篇文章全搞定&#xff01; 在工業生產中&#xff0c;尼龍輸送帶作為關鍵的物流傳輸設備&#xff0c;其選擇和使用直接關系到生產效率和成本控制。面對市面上琳瑯滿目的尼龍輸送帶產品&#xff0c;如何選購到性價比高…

PointCloudLib 點云投影到XOY平面功能實現 C++版本

0.實現效果 左圖為原始點云,右圖為投影到XOY平面上的點云 將三維的點云投影到二維平面,方便處理一些二維輪廓方面的計算。 可以投影到空間中任意平面上。 1.算法原理 原理 點云投影是將三維空間中的點云數據映射到一個二維平面上的過程。這通常通過以下步驟實現: 確定投…

使用Golang開發一個HTTP客戶端請求命令行工具

什么是Golang Golang&#xff0c;也被稱為Go語言&#xff0c;是由Google開發的一種開源的編程語言。它于2007年開始設計&#xff0c;于2009年首次公開發布。Golang被設計成一種通用的編程語言&#xff0c;旨在提供簡單、高效和可靠的軟件開發方式。Golang具有靜態類型、垃圾回…

微服務實踐k8sdapr開發部署調用

前置條件 安裝docker與dapr: 手把手教你學Dapr - 3. 使用Dapr運行第一個.Net程序安裝k8s dapr 自托管模式運行 新建一個webapi無權限項目 launchSettings.json中applicationUrl端口改成5001,如下: "applicationUrl": "http://localhost:5001" //Wea…

c#實現視頻播放

在winform上實現視頻播放常用的控件時media player&#xff0c;vs工具欄初始狀態下沒有&#xff0c;需要我們到com組件中添加。添加完成后&#xff0c;把media player控件拖拽到一個Form窗口中。 在此實現遍歷某個文件夾下是否有mp4視頻&#xff0c;如果有則播放視頻。&#x…

BeautifulSoup4通過lxml使用Xpath,以及獲取(定位)元素和其文本或者屬性

環境&#xff1a;win10&#xff0c;python3.8.10 首先需要安裝&#xff1a;beautifulsoup4&#xff0c;lxml 使用命令&#xff1a; pip38 install beautifulsoup4 pip38 install lxml 安裝完畢后查看一下&#xff1a; 寫代碼&#xff1a; from bs4 import BeautifulSoup …

Go 圖像處理

Golang中的image包提供了基本的圖像類型、顏色模型、以及用于處理圖像的各種函數和接口。 常用類型與接口 image.Image 接口 這是Go語言中處理圖像的核心接口&#xff0c;定義了所有圖像必須實現的方法&#xff1a; type Image interface {// Bounds returns the domain for…

rocketmq 學習二 基本概念

教程&#xff1a;基本概念 | RocketMQ 視頻教程 https://www.bilibili.com/video/BV1d5411y7UW?vd_sourcef1bd3b5218c30adf0a002c8c937e0a27 版本&#xff1a;5.0 一 基本概念 1.1 生產者/Producer 1.1.1 定義 消息發布者。是構建并傳輸消息到服務端的運行實體。…