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

2021-09-26 20:33:26 字數 758 閱讀 6027

title: 2019-8-20 二叉搜尋樹的後續遍歷序列

tags: 演算法,每日一題,二叉樹

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

2.1 思路解析

使用遞迴實現

首先遞迴基是當開始位置大於等於結束位置時返回true,說明這個時候只有乙個數了。

接下來就是查詢左右子樹分界位置對應的index了,這個很簡單遍歷一遍從beginend的序列,某個位置出現的元素比根大說明就是那個位置了。

然後再判斷從indexend位置所有值是否都比根大,如果不是則返回false

如果是則繼續遞迴比較左子樹和右子樹的情況,返回左子樹和右子樹的結果的與。

class solution 

bool verifybst(int be, int end, vector& sequence)

}//驗證右子樹的元素都大於根節點

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

return verifybst(be, index-1, sequence) && verifybst(index, end-1, sequence);

}};

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

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