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

2021-10-23 03:03:51 字數 486 閱讀 3703

題目描述:

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

解題思路:

1. 後序遍歷序列的最後乙個元素為二叉樹的根節點;

2. 二叉搜尋樹左子樹上所有的結點均小於根結點、右子樹所有的結點均大於根結點。

演算法步驟如下:

1. 找到根結點;

2. 遍歷序列,找到第乙個大於等於根結點的元素i,則i左側為左子樹、i右側為右子樹;

3. 我們已經知道i左側所有元素均小於根結點,那麼再依次遍歷右側,看是否所有元素均大於根結點;若出現小於根結點的元素,則直接返回false;若右側全都大於根結點,則:

4. 迴圈遍歷根結點。

class solution 

return true;

}};

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

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