- 921. Minimum Add to Make Parentheses Valid 使括号有效的最少添加
- 915. Partition Array into Disjoint Intervals 分割数组
- 932. Beautiful Array 漂亮数组
- 940. Distinct Subsequences II 不同的子序列 II
题目地址:https://leetcode.com/problems/construct-binary-search-tree-from-preorder-traversal/
Return the root node of a binary search tree that matches the given preorder
traversal.
(Recall that a binary search tree is a binary tree where for every node, any descendant of node.left
has a value < node.val
, and any descendant of node.right has a value > node.val
. Also recall that a preorder traversal displays the value of the node first, then traverses node.left
, then traverses node.right
.)
Example 1:
Input: [8,5,1,7,10,12]
Output: [8,5,10,1,7,null,12]
Note:
1、 1<=preorder.length<=100;
2、 Thevaluesofpreorderaredistinct.;
给出了一个BST的先序遍历,求该BST。
先序遍历一定先遍历了根节点,所以出现的第一个数字一定是根。那么BST的左子树都比根节点小,而先序遍历要把左子树遍历结束才遍历右子树,所以向后找第一个大于根节点数字位置,该位置就是右子树的根节点。
做一个递归即可。
Python代码如下:
# Definition for a binary tree node.
# class TreeNode(object):
# def __init__(self, x):
# self.val = x
# self.left = None
# self.right = None
class Solution(object):
def bstFromPreorder(self, preorder):
"""
:type preorder: List[int]
:rtype: TreeNode
"""
if not preorder: return None
root = TreeNode(preorder[0])
N = len(preorder)
i = 1
while i < N:
if preorder[i] > preorder[0]:
break
i += 1
root.left = self.bstFromPreorder(preorder[1:i])
root.right = self.bstFromPreorder(preorder[i:])
return root
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24
2022
DDKK.COM 弟弟快看-教程,程序员编程资料站,版权归原作者所有
本文经作者:负雪明烛 授权发布,任何组织或个人未经作者授权不得转发
我想知道是否可以构造以下函数 ix :: (Applicative a, Traversable t) => Int -> (v -> a v) -> (t v -> a (t v)) 对除第i个元素
精简版。 Scala 中的大多数泛型集合都有一个 map实际上,该方法将返回相同类型的集合。 (例如, List[A].map(f:A=>B) 返回一个 List[B] 。)Scala 集合库是明确设
早上好/下午好/晚上好。 因此,我们的数据结构类(class)给了我们一个作业,使用以下算法在 java 中分割灰度图像: Input: A gray-scale image with P pixel
我一直在想为什么 Traversable 类型类需要 Functor 和 Foldable,而不仅仅是 Foldable ,因为它不使用仿函数的任何部分? class (Functor t, Fold
JavaScript 和 CSS 在遍历 HTML 元素时都使用自己的 DOM 树。 在JavaScript中,我们可以使用它自己的DOM遍历方法如 element.parentNode elemen
如何在nodejs遍历模块中中断/停止遍历? 我正在遍历 json,在某些情况下,我想停止遍历。 遍历(req.body).forEach(函数(xnode){ log.info("检查 Node :
自然法规定: t . traverse f == traverse (t . f) -- for every applicative transformer t 现在对于法律的 RHS,如果 f 的类
我想在 Java8 节点流中转换树。 这是一个存储数据的节点树,可以选择: public class SelectTree { private D data; private boolean
有人可以向我解释一下,typeclass Traversable 的目的是什么? ? 类型类定义是: class (Functor t, Foldable t) => Traversable (t :
我正在研究Scala 2.8集合类的源代码。我对 scala.collection.Traversable 的层次结构有疑问。查看以下声明: package scala.collection
在我的 ArangoDB 图中,我有一个主题、与该主题关联的消息线程以及这些消息线程内的消息。我想以返回与消息线程关联的数据以及消息线程内的消息计数的方式遍历该图。 数据的结构相当简单:我有主题节点、
问题 1 - 在Scala文档中,我发现Traversable是一个带有抽象方法foreach的trait: http://www.scala-lang.org/docu/files/collecti
在 https://babeljs.io/当我想编译我的 ES6 代码时,将显示此错误: traverse.clearCache is not a function 我的代码是一个简单的代码,例如:
我有以下实现目录遍历的模块: module Walk ( walk ) where import Control.Monad import Contro
我试图弄清楚如何编写一个适用于任何 Traversable[_] 的函数式交换函数,给定一个集合和要交换的索引。我想出了以下内容: def swap[A, CC List(5,2,3,4,1) 我想
假设我们有一些类 Foo这样 Foo f 的实例为我们提供实现 Functor f 所需的一切, Foldable f和 Traversable f .为避免重复实例,可以见证 Foo 之间的这种关系
我记得在某处读到这样的类型不能是 Traversable : data Bar a = Bar a deriving(Show) instance Functor Bar where fmap f
我有一个玫瑰树结构,我想写一个 Traversable 例如。所以我从以下几点开始: data Tree a = Tree a [Tree a] deriving (Show) instance Fu
我正在努力解决如何使用 jQuery 选择特定元素。此处概述的条件: 在我的函数中的相关点,this 引用了一个span。 该 span 可能是子级、孙级或曾孙级,但在层次结构中的某个位置,它由 td
lens报价 holesOf ,这是这个假设函数的一个更通用和更强大的版本: holesList :: Traversable t => t a -> [(a, a -> t a)
我是一名优秀的程序员,十分优秀!