【數據結構】二叉樹篇|『構造二叉樹』刷題

在這里插入圖片描述

  • 博主簡介:努力學習的22級計算機科學與技術本科生一枚🌸
  • 博主主頁: @是瑤瑤子啦
  • 每日一言🌼: 所謂自由,不是隨心所欲,而是自我主宰。——康德

目錄

  • 一、前言
  • 二、刷題
    • 1、最大二叉樹
    • 2、從前序與中序遍歷序列構造二叉樹
    • 3、從中序與后序遍歷序列構造二叉樹
    • 4、 根據前序和后序遍歷構造二叉樹

一、前言

🍊 二叉樹的構造問題一般都是使用「分解問題」的思路:構造整棵樹 = 根節點 + 構造左子樹 + 構造右子樹
( 關鍵在于明確遞歸函數的定義,然后利用這個定義,構建二叉樹的套路很簡單,先找到根節點,然后找到并遞歸構造左右子樹即可)

二、刷題

1、最大二叉樹

🔗654. 最大二叉樹
在這里插入圖片描述

 public TreeNode constructMaximumBinaryTree(int[] nums) {if(nums==null||nums.length==0){return null;}//1、找到最大元素,構造根節點int max = nums[0];int index = 0;for (int i = 1; i < nums.length; i++){if(nums[i] > max){index = i;max = nums[i];}}TreeNode root = new TreeNode(max);//左子樹和右子樹數組構造int[] numsLeft = Arrays.copyOfRange(nums, 0, index);int[] numsRight = Arrays.copyOfRange(nums,index+1, nums.length);root.left = constructMaximumBinaryTree(numsLeft);root.right = constructMaximumBinaryTree(numsRight);return root;}

2、從前序與中序遍歷序列構造二叉樹

🔗105. 從前序與中序遍歷序列構造二叉樹

  • 👧🏻思路:

    • 大的框架還是分解成子問題,這里定義一個遞歸函數:build(遞歸函數的定義:給定二叉樹前序遍歷、中序遍歷數組、前序數組起始坐標、前序數組末尾坐標、中序數組起始坐標、中序數組末尾坐標)
    • 在遞歸函數前序位置需要確定左子樹兩個數組的的四個坐標和右子樹的四個坐標,核心是算出當前root在中序數組中的位置rootIndex
      在這里插入圖片描述
  • 🙇🏻?♀?代碼:

    	public TreeNode buildTree(int[] preorder, int[] inorder) {//遞歸函數的定義:給定二叉樹前序遍歷、中序遍歷數組、前序數組起始坐標、前序數組末尾坐標、中序數組起始坐標、中序數組末尾坐標int pStart = 0;int pEnd = preorder.length-1;int iStart = 0;int iEnd = inorder.length-1;return build(preorder,inorder, pStart, pEnd, iStart, iEnd);}public TreeNode build(int[] preorder, int[] inorder, int pStart, int pEnd, int iStart, int iEnd){if(pStart > pEnd){return null;}//1、先在前序數組中找到根節點TreeNode root = new TreeNode(preorder[pStart]);//2、在中序數組中找到根節點,劃分左右數組int rootIndex = -1;int leftSize = 0;for(int  i = iStart; i <= iEnd; i++){if(inorder[i] == root.val){rootIndex = i;leftSize = i-iStart;break;}}root.left = build(preorder, inorder, pStart+1, pStart+leftSize, iStart ,rootIndex-1);root.right = build(preorder, inorder, pStart+leftSize+1, pEnd, rootIndex+1, iEnd);return root;}
    

3、從中序與后序遍歷序列構造二叉樹

🔗106. 從中序與后序遍歷序列構造二叉樹
在這里插入圖片描述

  • 👧🏻思路:

    • 同上,關鍵在于四個坐標的確定要準確
      在這里插入圖片描述
  • 🙇🏻?♀?代碼:

     public TreeNode buildTree(int[] inorder, int[] postorder) {int inStart = 0;int inEnd = inorder.length -1;int posStart = 0;int posEnd = postorder.length - 1;return build(inorder, postorder, inStart, inEnd, posStart, posEnd);}public TreeNode build(int[] inorder, int[] postorder, int inStart, int inEnd, int posStart, int posEnd){if(posStart>posEnd){return null;}TreeNode root = new TreeNode(postorder[posEnd]);//得到根節點//找到根節點在中序數組中的位置int index = 0;int leftSize = 0;for(int i = inStart; i <= inEnd; i++ ){if(inorder[i] == root.val){index = i;leftSize = i - inStart;break;}}//*******構建左子樹右子樹 */root.left = build(inorder, postorder, inStart, index-1, posStart,posStart+leftSize -1);root.right = build(inorder, postorder, index+1, inEnd, posStart+leftSize,posEnd-1);return root;}
    

4、 根據前序和后序遍歷構造二叉樹

🔗889. 根據前序和后序遍歷構造二叉樹
在這里插入圖片描述

  • 👧🏻思路:
    • 根據我們知道,只通過前序+后序是無法唯一構造一棵二叉樹的。那么當然了,這題告訴我們有多個答案只用返回一個即可

    • 前兩個(前序+中序&&中序+后序)可以唯一確定是因為通過前序/后序數組可以在前序位置唯一確定根節點root,然后在中序數組中可以根據root分成左中序數組和右中序數組,所以是可以確定唯一一顆二叉樹的。

    • 而前序+后序按照這個思路其實也不是不行,因為前序和后序的數組劃分是這樣的:

      🤔咦,根據上圖,貌似前序和中序可以構造唯一二叉樹呀
      🙅🏻?♀?不對,因為這里我們默認了一個大前提:root+1是left子樹的跟,也就是默認了左子樹至少有一個節點。但是實際上 ,左子樹可能為空!——我們只是選取了其中一種可能情況而言。

    • 🙋🏻構建思路
      1. 首先將前序/后序遍歷的第一個節點作為根節點root
      2. 前序數組中,root后面相鄰元素作為左子樹的根節點(坐標記為preStartL = preStart+1);
      3. 根據前序數組中的左子樹根節點在后序數組中找到左子樹的根節點:坐標記為posEndL
      4. 從而求得左子樹節點個數leftSize = posStartL - posStart + 1,將左右子樹劃分
      5. 劃分后即可確定左右子樹的四個坐標點,帶入遞歸函數分解成子問題即可

在這里插入圖片描述

  • 🙇🏻?♀?代碼:

     public TreeNode constructFromPrePost(int[] preorder, int[] postorder) {int preStart = 0;int preEnd = preorder.length -1;int posStart = 0;int posEnd = postorder.length - 1;return build(preorder, postorder, preStart, preEnd, posStart, posEnd);}public TreeNode build(int[] preorder, int[] postorder, int preStart, int preEnd, int posStart, int posEnd){if (preStart > preEnd) {return null;}//****** */!注意,這種情況必須特判!*****if (preStart == preEnd) {return new TreeNode(preorder[preStart]);}//************************************* */TreeNode root = new TreeNode(preorder[preStart]);//1、得到根節點//2、key:求leftSizeint preStartL = preStart+1;//int posEndL = -1;//2.1:找左子樹根節點在后序數組中的位置for(int i = posStart; i <= posEnd; i++ ){if(postorder[i] == preorder[preStartL]){posEndL = i;break;}}int leftSize = posEndL - posStart + 1;root.left = build(preorder, postorder, preStartL, preStartL + leftSize -1, posStart, posEndL);root.right = build(preorder, postorder, preStartL + leftSize, preEnd, posEndL + 1, posEnd -1 );return root;}
    
  • 🍊注意!:在上面代碼重點標出部分,需要特判的原因是:我們在思路部分已經講過,這種方法默認左子樹至少有一個節點(一棵樹至少有兩個節點),而preStart == preEnd并不滿足這個大前提,所以需要特判!!


💐若有不懂的地方,歡迎隨時在評論區or私信找瑤瑤子交流討論🌺

在這里插入圖片描述

  • Java島冒險記【從小白到大佬之路】

  • LeetCode每日一題–進擊大廠

  • Go語言核心編程

  • 算法

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

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

相關文章

怎么使用手機遠程控制Win10電腦?

可以使用手機遠程控制電腦嗎&#xff1f; “近期&#xff0c;我將出差一段時間。問題是&#xff0c;我希望能夠從很遠的地方瀏覽家里電腦上的一些東西&#xff0c;但我不會一直隨身攜帶笨重的筆記本電腦。我可以手機遠程訪問Windows電腦嗎&#xff1f; ” 當然&am…

SpringBoot請求響應

簡單參數 1. 原始方式獲取請求參數 Controller方法形參中聲明httpServletRequest對象 調用對象的getParameter參數名 RestController public class RequestController {RequestMapping("/simpleParam")public String simpleParam(HttpServletRequest request){Strin…

Pytorch源碼搜索與分析

PyTorch的的代碼主要由C10、ATen、torch三大部分組成的。其中&#xff1a; C10 C10&#xff0c;來自于Caffe Tensor Library的縮寫。這里存放的都是最基礎的Tensor庫的代碼&#xff0c;可以運行在服務端和移動端。PyTorch目前正在將代碼從ATen/core目錄下遷移到C10中。C10的代…

12-數據結構-數組、矩陣、廣義表

數組、矩陣、廣義表 目錄 數組、矩陣、廣義表 一、數組 二.矩陣 三、廣義表 一、數組 這一章節理解基本概念即可。數組要看清其實下標是多少&#xff0c;并且二維數組&#xff0c;存取數據&#xff0c;要先看清楚是按照行存還是按列存&#xff0c;按行則是正常一行一行的去讀…

學習Vue:slot使用

在Vue.js中&#xff0c;組件高級特性之一是插槽&#xff08;Slots&#xff09;。插槽允許您在父組件中插入內容到子組件的特定位置&#xff0c;從而實現更靈活的組件復用和布局控制。本文將詳細介紹插槽的使用方法和優勢。 什么是插槽&#xff1f; 插槽是一種讓父組件可以向子…

AIF360入門教學

1、AIF360簡介 AI Fairness 360 工具包(AIF360)是一個開源軟件工具包&#xff0c;可以幫助檢測和緩解整個AI應用程序生命周期中機器學習模型中的偏見。在整個機器學習的過程中&#xff0c;偏見可能存在于初始訓練數據、創建分類器的算法或分類器所做的預測中。AI Fairness 360…

OPENCV C++(十一)

鼠標響應函數 //鼠標響應函數 void on_mouse(int EVENT, int x, int y, int flags, void* userdata) {Mat hh;hh *(Mat*)userdata;switch (EVENT){case EVENT_LBUTTONDOWN:{vP.x x;vP.y y;drawMarker(hh, vP, Scalar(255, 255, 255));//circle(hh, vP, 4, cvScalar(255, 255…

人工智能在監控系統中的預測與優化:提升效率和響應能力

引言&#xff1a;人工智能的發展給監控系統帶來了新的可能性&#xff0c;通過分析歷史監控數據和其他相關數據&#xff0c;人工智能可以預測未來可能發生的事件&#xff0c;如交通擁堵、安全隱患等&#xff0c;并幫助優化監控系統的配置和資源分配。這種預測和優化的能力可以提…

2023年國賽數學建模思路 - 復盤:校園消費行為分析

文章目錄 0 賽題思路1 賽題背景2 分析目標3 數據說明4 數據預處理5 數據分析5.1 食堂就餐行為分析5.2 學生消費行為分析 建模資料 0 賽題思路 &#xff08;賽題出來以后第一時間在CSDN分享&#xff09; https://blog.csdn.net/dc_sinor?typeblog 1 賽題背景 校園一卡通是集…

vue3表格,編輯案例

index.vue <script setup> import { onMounted, ref } from "vue"; import Edit from "./components/Edit.vue"; import axios from "axios";// TODO: 列表渲染 const list ref([]); const getList async () > {const res await ax…

6.2.0在線編輯:GrapeCity Documents for Word (GcWord) Crack

GrapeCity Word 文檔 (GcWord) 支持 Office Math 函數以及轉換為 MathML GcWord 現在支持在 Word 文檔中創建和編輯 Office Math 內容。GcWord 中的 OMath 支持包括完整的 API&#xff0c;可處理科學、數學和通用 Word 文檔中廣泛使用的數學符號、公式和方程。以下是通過 OMa…

無法在 macOS Ventura 上啟動 Multipass

異常信息 ? ~ sudo multipass authenticate Please enter passphrase: authenticate failed: Passphrase is not set. Please multipass set local.passphrase with a trusted client. ? ~ multipass set local.passphrase Please enter passphrase: Please re-enter…

大語言模型LLM的一些點

LLM發展史 GPT模型是一種自然語言處理模型,使用Transformer來預測下一個單詞的概率分布,通過訓練在大型文本語料庫上學習到的語言模式來生成自然語言文本。 GPT-1(117億參數),GPT-1有一定的泛化能力。能夠用于和監督任務無關的任務中。GPT-2(15億參數),在生成方面表現出很…

vue自定義指令--動態參數綁定

在企業微信側邊欄應用中&#xff0c;給dialog添加了拖拽功能&#xff0c;但是因為dialog高度超過了頁面高度&#xff0c;所以高度100%時拖拽有個bug--自動貼到窗口頂部而且企業側邊欄寬高都有限制&#xff0c;拖拽效果并不理想&#xff0c;所以就想縮小dialog再進行拖拽。 拖拽…

IntelliJ IDEA和Android studio怎么去掉usage和作者提示

截止到目前我已經寫了 600多道算法題&#xff0c;其中部分已經整理成了pdf文檔&#xff0c;目前總共有1000多頁&#xff08;并且還會不斷的增加&#xff09;&#xff0c;大家可以免費下載 下載鏈接&#xff1a;https://pan.baidu.com/s/1hjwK0ZeRxYGB8lIkbKuQgQ 提取碼&#xf…

java處理CSV文件

文章目錄 1. 方法2. maven依賴3. 示例代碼 1. 方法 opencsv–>CSVParser&#xff1b;commons-csv–>CSVReader&#xff1b;有時候文本里有逗號可能會導致錯誤分割 2. maven依賴 <dependency><groupId>org.apache.commons</groupId><artifactId>…

457. 環形數組是否存在循環

457. 環形數組是否存在循環 原題鏈接&#xff1a;完成情況&#xff1a;解題思路&#xff1a;參考代碼&#xff1a;經驗吸取 原題鏈接&#xff1a; 457. 環形數組是否存在循環 https://leetcode.cn/problems/circular-array-loop/description/ 完成情況&#xff1a; 解題思路…

使用Pandas進行數據清理的入門示例

數據清理是數據分析過程中的關鍵步驟&#xff0c;它涉及識別缺失值、重復行、異常值和不正確的數據類型。獲得干凈可靠的數據對于準確的分析和建模非常重要。 本文將介紹以下6個經常使用的數據清理操作&#xff1a; 檢查缺失值、檢查重復行、處理離群值、檢查所有列的數據類型…

explicit關鍵字 和 static成員

explicit關鍵字 和 static成員 1、explicit 關鍵字2、static成員&#xff08;靜態成員變量屬于類的&#xff08;只有所屬這個類的對象才能修改&#xff09;&#xff0c;不同于全局變量&#xff08;任何對象都能修改&#xff09;&#xff09;2.1 定義和性質2.2 靜態成員的使用場…

opencv進階02-在圖像上繪制多種幾何圖形

OpenCV 提供了方便的繪圖功能&#xff0c;使用其中的繪圖函數可以繪制直線、矩形、圓、橢圓等多種幾何圖形&#xff0c;還能在圖像中的指定位置添加文字說明。 OpenCV 提供了繪制直線的函數 cv2.line()、繪制矩形的函數 cv2.rectangle()、繪制圓的函數cv2.circle()、繪制橢圓的…