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

2022-05-09 08:54:12 字數 471 閱讀 6312

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

public class solution 

public boolean check(int array,int begin,int end)

}//如果沒有找到比根節點大的,說明沒有右子樹,那麼直接判斷左子樹

if(firstmax == -1)

return check(array,begin,end-1);

//如果有右子樹,那麼檢查右子樹是否全部大於根節點

for(int i = firstmax+1;i < end;i++)

//遞迴檢查左右子樹

return (check(array,begin,firstmax-1) && check(array,firstmax,end-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...