演算法 二叉搜尋樹的後序遍歷序列

2022-03-03 20:05:16 字數 1124 閱讀 3153

* @description 二叉搜尋樹的後序遍歷序列* @問題:題目描述

* 輸入乙個整數陣列,判斷該陣列是不是某二叉搜尋樹的後序遍歷的結果。

* 如果是則輸出yes,否則輸出no。假設輸入的陣列的任意兩個數字都互不相同。

* @思路:

1:判斷長度極端情況,為零則直接返回false

2:判斷為節點小於等於頭節點的極端情況;

3:找到中間根節點,大於尾部節點的時候break;

4:直接根據二叉樹後序遍歷,右子樹都大於根節點,小於則直接返回false;再遞迴左右子樹;

package

lg.nowcoder;

/*** @author liguo

* @description 二叉搜尋樹的後序遍歷序列

* @問題: 題目描述

* 輸入乙個整數陣列,判斷該陣列是不是某二叉搜尋樹的後序遍歷的結果。

* 如果是則輸出yes,否則輸出no。假設輸入的陣列的任意兩個數字都互不相同。

* @思路:

1:判斷長度極端情況,為零則直接返回false

2:判斷為節點小於等於頭節點的極端情況;

3:找到中間根節點,大於尾部節點的時候break;

4:直接根據二叉樹後序遍歷,右子樹都大於根節點,小於則直接返回false;再遞迴左右子樹;

* @data 2018-09-23 23:52 */

public

class

solution25

public

boolean istreebst(int sequence,int start,int

end )

//從根到尾部都應該比尾部的節點大;

for (int j = i; j < end; j++)

return istreebst(sequence, start, i-1) && istreebst(sequence, i, end-1);}}

view code

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

題目 輸入乙個整數陣列,判斷該陣列是不是某二叉搜尋樹的後序遍歷的結果。如果是返回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...