二叉搜尋樹的後序遍歷序列 js

2021-09-23 17:16:56 字數 798 閱讀 3834

輸入乙個整數陣列,判斷該陣列是不是某二叉搜尋樹的後序遍歷的結果。如果是則輸出yes,否則輸出no。假設輸入的陣列的任意兩個數字都互不相同。

二叉搜尋樹的特點:某乙個節點左子樹的所有節點的值都比該節點小,右子樹的所有節點的值都比該節點大

依次與陣列最後乙個值比較,一直小於最後乙個數的是左子樹的,計數,剩下的是右子樹的,依次判斷剩下的是否全部大於最後乙個數,若否,則為false。

使用遞迴,依次判斷每乙個子陣列是否滿足上乙個條件

小技巧:將返回true的條件由s==e改為s>=e,則無需判斷是否有lesse == s || lesse == e,直接return judge(arr,s,lesse-1) && judge(arr,lesse,e-1)即可。(否則會出現sfunction

verifysquenceofbst

(sequence)

var i = end;

while

(i > sta && sequence[i-1]

> sequence[end]

)for

(var j = i -

1;j >= sta;

--j)

}return

judge

(sequence,sta,i -1)

&&(judge

(sequence,i,end -1)

);}if

(!sequence.length)

return

judge

(sequence,

0, sequence.length -1)

;}

二叉搜尋樹的後序遍歷序列

題目 輸入乙個整數陣列,判斷該陣列是不是某二叉搜尋樹的後序遍歷的結果。如果是返回true,否則返回false。假設輸入的陣列的任意兩個數字都不相同。解答 二叉搜尋樹後序遍歷最後訪問的是根節點,根據根節點將陣列分成兩部分,前面一部分即左子樹值小於根節點值,後面一部分即右子樹的值大於根節點 再遞迴的檢查...

二叉搜尋樹的後序遍歷序列

輸入乙個整數陣列,判斷該陣列是不是某二叉搜尋樹的後序遍歷的結果。如果是則輸出yes,否則輸出no。假設輸入的陣列的任意兩個數字都互不相同。include using namespace std bool verifysquenceofbst int sequence,int length int j...

二叉搜尋樹的後序遍歷序列

輸入乙個整數陣列,判斷該陣列是不是某二叉搜尋樹的後序遍歷的結果。如果是則輸出yes,否則輸出no。假設輸入的陣列的任意兩個數字都互不相同。class solution 在二叉搜尋樹中右子樹的結點大於根結點 int j i for j0 left verifysquenceofbst lefttree...