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

2022-05-30 10:57:09 字數 893 閱讀 4526

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

* 遞迴實現檢測

*

* 對於後序遍歷來說,序列陣列的最後乙個元素一定是根節點,

* 則根據這個元素,將前面的陣列分為左、右兩個部分,左側部分都小,右側部分都大,

* 如果右側部分有比該根節點小的元素,那麼就不是後序遍歷,如此遞迴進行(左半部分在上一步驟已經比較過了,所以不需要比較啦)

bool search(vector&a,int start,int

end)

inti;

int rootval=a[end];//

根節點的值

for(i=start;i1;i++)//

從左到右找第乙個大於根節點的值(即將陣列分為兩部分,左邊小於根,右邊大於根)

if(a[i]>rootval)

break

;

//從位置i此處去遍歷陣列,如果出現小於根節點的值,則返回false

for(int j=i;j1;j++)

if(a[j]return

false

;

//確保左右子樹部分仍然是後續序列

return search(a,start,i-1)&&search(a,i,end-1

); }

bool verifysquenceofbst(vectorsequence)

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

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