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

2021-09-25 09:23:15 字數 730 閱讀 9768

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

思路:參考《劍指offer》

bool lf = true;

if(left.size() > 0)

lf = verifysquenceofbst(left);

bool rg = true;

if(right.size() > 0)

rg = verifysquenceofbst(right);

函式的引數如果為空,就返回false

但是在函式內部遞迴呼叫該函式時,如果函式為空,是不返回false,應該返回true,因此就有了這種寫法!!!

class solution 

//根節點的右子樹節點的值都大於根節點的值

int j = i;

for(; j < sequence.size() - 1; j++)

bool lf = true;

if(left.size() > 0)

lf = verifysquenceofbst(left);

bool rg = true;

if(right.size() > 0)

rg = verifysquenceofbst(right);

return lf && rg;

}};

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

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