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

2021-08-30 19:37:30 字數 696 閱讀 5838

// 面試題33:二叉搜尋樹的後序遍歷序列

// 題目:輸入乙個整數陣列,判斷該陣列是不是某二叉搜尋樹的後序遍歷的結果。

// 如果是則返回true,否則返回false。假設輸入的陣列的任意兩個數字都互不相同。

// bst:binary search tree,二叉搜尋樹

static bool is_bst_lrd(const int* arr, int len)

int root = arr[len - 1];

// 在二叉搜尋樹中左子樹的結點小於根結點

int i = 0;

for(; i < len-1; ++ i)

}// 在二叉搜尋樹中右子樹的結點大於根結點

int j = i;

for(; j < len - 1; ++ j)

}// 判斷左子樹是不是二叉搜尋樹

bool left = true;

if(i > 0)

left = is_bst_lrd(arr, i);

// 判斷右子樹是不是二叉搜尋樹

bool right = true;

if(i < len - 1)

right = is_bst_lrd(arr + i, len - i - 1);

return (left && right);

}

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

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