二叉搜尋樹的後序序列

2021-09-24 00:06:43 字數 804 閱讀 6281

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

1、因為是二叉搜尋樹 ,所以每個結點的左邊都小於根結點,右邊都大於根結點;

2、而二叉搜尋樹的子樹也是二叉搜尋樹,因此也符合1

3、因此,除了最後結點之外的序列前部分小於結點值,後半部分大於結點值,因此可以加乙個變數計算結點數量

4、如果: 遍歷小於結點值和大於結點值時的下標如果剛好是倒數第二個元素,說明是此時搜尋二叉樹(每科子樹都要滿足此要求)

示例輸出:

序列: 3,2,6,5,12,13,4,7 不是某搜尋二叉樹的後序序列

序列: 3,2,6,5,9,13,12,7 是某搜尋二叉樹的後序序列

#include #include #include using namespace std;

class solution ;

vectorright_sequence = ;

cout << "序列: 3,2,6,5,12,13,4,7 ";

switch (re.verifysquenceofbst(error_sequence))

cout << "序列: 3,2,6,5,9,13,12,7 " ;

switch (re.verifysquenceofbst(right_sequence))

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...