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

2021-08-19 18:17:03 字數 888 閱讀 6035

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

基本思路:首先要搞清楚二叉搜尋樹以及後序遍歷的定義。在後序遍歷得到的序列中,最後乙個數字是樹的根節點的值。陣列中前面的數字可以分為兩部分:第一部分為左子樹結點的值,他們都比根節點小;第二部分是右子樹結點的值,他們都比根節點的值大。

# -*- coding:utf-8 -*-

class

solution:

defverifysquenceofbst

(self, sequence):

# write code here

if sequence:

i = len(sequence) - 1

root = sequence[i]

i -= 1

while sequence[i] > root and i >= 0:

i -= 1

for j in range(0, i + 1):

if sequence[j] > root:

return

false

left = true

if i > 0:

left = self.verifysquenceofbst(sequence[0:i + 1])

right = true

if i < len(sequence) - 3:

right = self.verifysquenceofbst(sequence[i + 1:len(sequence) - 1])

return left and right

else:

return

false

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

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