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

2021-07-13 11:44:51 字數 725 閱讀 4699

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

演算法:後續遍歷最後乙個數為根,陣列中小於root為左子樹,大於root 為右子樹。

1)如果陣列中第乙個數字就大於根說明沒有左子樹,意味著所有數都應該大於根。

2)如果有左子樹,那麼右子樹中不能有小於根的值。

即要求左子樹中不能有大於根的值,右子樹中不能有小於根的值。

**

#include

#include

using namespace

std;

class

solution

bool verifysquenceofbsthelper(vector

sequence)

for(;i1

;i++)}}

//沒有左子樹

else}}

return verifysquenceofbsthelper(left)&&verifysquenceofbsthelper(right);}};

int main() ;

int a =;

int b =;

vector

v(c,c+4);

cout

"hello, world!"

<< endl;

return 0;

}

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

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