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

2021-09-26 04:34:46 字數 1017 閱讀 8679

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

二叉搜尋樹:左節點《根節點《右節點

class solution:

def verifypostorder(self, postorder: list[int]) -> bool:

#二叉搜尋樹:左節點《根節點《右節點

def f(i,j):

if i>=j: #當前元素只有乙個

return true

p=iwhile postorder[p]postorder[j]:

p+=1

return p==j and f(i,right-1) and f(right,j-1)

return f(0,len(postorder)-1)

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

class solution:

def verifysquenceofbst(self, sequence):

# write code here

if not sequence or len(sequence)<=0:

return false

root=sequence[-1]

i=0#找出左小右大的分界點i,此時i屬於右子樹

for node in sequence[:-1]:

if node > root:

break

i+=1

#如果在右子樹中有比根節點小的值,直接返回false

for node in sequence[i:-1]:

if node < root:

return false

#判斷左子樹是否為二叉搜尋樹

left=true

if i>0:

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

#判斷右子樹是否為二叉搜尋樹

right=true

if i

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

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