題目描述
輸入兩棵二叉樹A,B,判斷B是不是A的子結(jié)構(gòu)。(ps:我們約定空樹不是任意一個樹的子結(jié)構(gòu))
分析假設(shè)樹A的根節(jié)點(diǎn)ra和樹B的根節(jié)點(diǎn)rb值相同,那么接下來就以這兩個節(jié)點(diǎn)開始依次比較ra.left和rb.left、ra.right和rb.right,過程中只要有一個不相同則返回;繼續(xù)比較ra.left和rb是否相同、ra.right和rb是否相同,就這樣依次進(jìn)行下去,時間復(fù)雜度則為O(樹A的節(jié)點(diǎn)數(shù))*O(樹B的節(jié)點(diǎn)數(shù))
代碼實(shí)現(xiàn)/* function TreeNode(x) { this.val = x; this.left = null; this.right = null; } */ function HasSubtree(r1, r2) { if(r1 === null || r2 === null) return false; return check(r1, r2) || HasSubtree(r1.left, r2) || HasSubtree(r1.right, r2); } function check(a,b){ if(b === null) return true; if(a === null || a.val !== b.val) return false; return check(a.left, b.left) && check(a.right, b.right); }
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/108115.html
文章目錄 一、題目1、題目描述2、基礎(chǔ)框架3、原題鏈接 二、解題報(bào)告1、思路分析2、時間復(fù)雜度3、代碼詳解 三、本題小知識四、加群須知 一、題目 1、題目描述 ??給你一棵二叉搜索樹,請按 中序遍歷 將其重新排列為一棵遞增順序搜索樹,使樹中最左邊的節(jié)點(diǎn)成為樹的根節(jié)點(diǎn),并且每個節(jié)點(diǎn)沒有左子節(jié)點(diǎn),只有一個右子節(jié)點(diǎn)。??樣例輸入: [5,3,6,2,4,null,8,1,null,null,nu...
摘要:題目描述輸入一棵二叉搜索樹,將該二叉搜索樹轉(zhuǎn)換成一個排序的雙向鏈表。要求不能創(chuàng)建任何新的結(jié)點(diǎn),只能調(diào)整樹中結(jié)點(diǎn)指針的指向。 題目描述 輸入一棵二叉搜索樹,將該二叉搜索樹轉(zhuǎn)換成一個排序的雙向鏈表。要求不能創(chuàng)建任何新的結(jié)點(diǎn),只能調(diào)整樹中結(jié)點(diǎn)指針的指向。 分析 如果是這樣一棵二叉搜索樹: showImg(https://segmentfault.com/img/remote/14600000...
摘要:樹中結(jié)點(diǎn)的最大層次稱為樹的深度或高度。二叉樹有深度遍歷和廣度遍歷,深度遍歷有前序中序和后序三種遍歷方法。二叉樹的前序遍歷可以用來顯示目錄結(jié)構(gòu)等中序遍歷可以實(shí)現(xiàn)表達(dá)式樹,在編譯器底層很有用后序遍歷可以用來實(shí)現(xiàn)計(jì)算目錄內(nèi)的文件及其信息等。 樹的簡介 棧、隊(duì)列、鏈表等數(shù)據(jù)結(jié)構(gòu),都是順序數(shù)據(jù)結(jié)構(gòu)。而樹是非順序數(shù)據(jù)結(jié)構(gòu)。樹型結(jié)構(gòu)是一類非常重要的非線性結(jié)構(gòu)。直觀地,樹型結(jié)構(gòu)是以分支關(guān)系定義的層次結(jié)...
摘要:通過對樹進(jìn)行層級控制,同一個父節(jié)點(diǎn)下的所有子節(jié)點(diǎn)。新老集合進(jìn)行差異化對比,發(fā)現(xiàn),則創(chuàng)建并插入至新集合,刪除老集合以此類推,創(chuàng)建并插入和,刪除和。 虛擬dom Jsx 表面寫的是html,其實(shí)內(nèi)部執(zhí)行的是一段js createElement React.createElement( type, [props], [...children] ) createElement把這個...
摘要:題目描述輸入一棵二叉樹,求該樹的深度。遞歸解法非遞歸解法原來標(biāo)識當(dāng)前層是否遍歷完畢當(dāng)前彈出元素為時,說明一層以及遍歷完畢了,所以最后一層的彈出時不能再往隊(duì)列里面加了 題目描述 輸入一棵二叉樹,求該樹的深度。從根結(jié)點(diǎn)到葉結(jié)點(diǎn)依次經(jīng)過的結(jié)點(diǎn)(含根、葉結(jié)點(diǎn))形成樹的一條路徑,最長路徑的長度為樹的深度。 遞歸解法 function TreeNode(x) { this.val = x;...
閱讀 3569·2021-11-25 09:43
閱讀 3149·2021-10-08 10:04
閱讀 1636·2019-08-26 12:20
閱讀 2068·2019-08-26 12:09
閱讀 610·2019-08-23 18:25
閱讀 3582·2019-08-23 17:54
閱讀 2338·2019-08-23 17:50
閱讀 815·2019-08-23 14:33