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

2022-07-29 02:57:13 字數 839 閱讀 9116

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

思路:這題不要使用陣列進行儲存,這種效率太低了,對比重建二叉樹。

這種邊界情況很多的題目,一定要寫個例子進行判斷再程式設計,不然很容易邊界錯誤。

幾個細節,i < end,因為最後乙個是root,執行完乙個迴圈後,i的值指向leftend的後乙個。

for(exp1;exp2;exp3){};

記住先初始化exp1,然後執行判斷語句exp2,再執行函式體,然後執行exp3,這是乙個迴圈;

第二次的時候先判斷exp2 -> 執行函式體 - > 執行exp3;

不管++i還是i++,都是自增之後在判斷條件2.

class

solution

int i =start;

for(i = start;i < end;++i)

}for(int j = i;j < end;++j)

}

return helper(sequence,start,i - 1) && helper(sequence,i,end - 1

); }

bool verifysquenceofbst(vectorsequence)

bool res = true

; res = helper(sequence,0,sequence.size() - 1

);

return

res;

}};

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

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