码迷,mamicode.com
首页 > 其他好文 > 详细

Leetcode 95. Unique Binary Search Tree II

时间:2016-12-19 13:40:49      阅读:168      评论:0      收藏:0      [点我收藏+]

标签:start   应该   res   bin   []   self   generate   arc   ret   

由于BST的性质,所以右子树或者左子树中Node的值是连续的: 左子树 = [1, i -1], root = i, 右子树 = [i + 1, n]。使用一个递归函数构造这个BST。其中返回值应该是所有的Unique BST的root node。

 1 def generateTrees(self, n):
 2         """
 3         :type n: int
 4         :rtype: List[TreeNode]
 5         """
 6         if n == 0:
 7             return []
 8         return self.buildTree(1, n)
 9     
10     def buildTree(self, start, end):
11         result = []
12         if start > end:
13             result.append(None)
14             return result
15         
16         for i in range(start, end + 1):
17             leftChild = self.buildTree(start, i - 1)
18             rightChild = self.buildTree(i+1, end)
19             
20             for l in leftChild:
21                 for r in rightChild:
22                     node = TreeNode(i)
23                     node.left = l
24                     node.right = r
25                     result.append(node)
26         
27         return result

 

Leetcode 95. Unique Binary Search Tree II

标签:start   应该   res   bin   []   self   generate   arc   ret   

原文地址:http://www.cnblogs.com/lettuan/p/6196912.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!