Middle-题目12:96. Unique Binary Search Trees

原创 2016年05月31日 15:32:52

题目原文:
Given n, how many structurally unique BST’s (binary search trees) that store values 1…n?

For example,
Given n = 3, there are a total of 5 unique BST’s.

   1         3     3      2      1
    \       /     /     /  \      \
     3     2     1      1   3      2
    /     /       \                 \
   2     1         2                 3

题目大意:
n个节点的二叉排序树有几种?
题目分析:
等价于求Catalan数。(证明我也不知道。求大神给出证明。)
源码:(language:java)

public class Solution {
    public int numTrees(int n) {
        int[] catalan=new int[]{1, 1, 2, 5, 14, 42, 132, 429, 1430, 4862, 16796, 58786, 208012, 742900, 2674440, 9694845, 35357670, 129644790, 477638700, 1767263190};
        return catalan[n];
    }
}

成绩:
0ms,beats 2.75%,众数0ms,92.25%.
Cmershen的碎碎念:
关于Catalan数的性质见https://zh.wikipedia.org/wiki/%E5%8D%A1%E5%A1%94%E5%85%B0%E6%95%B0

版权声明:完整版Leetcode题解请出门左转https://github.com/cmershen1/leetcode/tree/master/docs

【算法分析与设计】【第十周】96. Unique Binary Search Trees

动态规划基础训练2。 给定一个数n,求出节点数为n的二叉搜索树的个数。
  • raoyx
  • raoyx
  • 2017年11月10日 08:56
  • 45

Unique Binary Search Trees II 不同的树个数(重重重)

题目: 点击打开链接 解答:
  • skyoceanlover
  • skyoceanlover
  • 2014年08月26日 21:02
  • 210

二叉搜索树(Binary Search Tree )的定义及分析

定义:     二叉搜索树或者是一棵空树,或者是具有下列性质的二叉树: 每个结点都有一个作为搜索依据的关键码(key),所有结点的关键码互不相同。 左子树(如果非空)上所...
  • jsh13417
  • jsh13417
  • 2013年01月22日 21:59
  • 3329

线索二叉树(Threaded BinaryTree)

线索二叉树 一、写在前面    本文主要介绍了中序线索化二叉树及中序线索化二叉树遍历。前序与后序原理相似,但在前、后序线索化二叉树中查找节点的后继较容易,而查找前驱要知道其双亲的信息,前、后序线索化二...
  • demi_hu
  • demi_hu
  • 2017年04月15日 12:54
  • 357

二叉搜索树(Binary Search Tree)的插入与删除

二叉搜索树的插入关键是要找到元素应该插入的位置,可以采用与Find类似的方法。 二叉搜索树的删除则要考虑三种情况:   1.要删除的是叶节点:直接删除,并再修改其父节点指针置为NULL ...
  • song_hui_xiang
  • song_hui_xiang
  • 2015年08月16日 13:10
  • 977

【HDU5573 2015上海赛区B】【构造 二进制思想】Binary Tree 二叉树上走m层加减数使得最后权值恰为n

Binary Tree Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/65536 K (Java/Others) Tota...
  • snowy_smile
  • snowy_smile
  • 2015年11月29日 11:47
  • 939

ABAP性能优化技巧—使用二分查找(Binary Search)选项

READ命令使用顺序查找数据表,这会降低处理速度。取而代之,使用binary search的附加命令,可以使用二分查找算法,可以帮助加快内表查找速度。 在使用binary search之前必须首先将内...
  • Victor9279
  • Victor9279
  • 2016年11月02日 14:52
  • 561

数据结构(Java语言)——BinarySearchTree简单实现

二叉树的一个重要应用是它们在查找中的使用。使二叉树成为二叉查找树的性质是,对于树中的每个节点X,它的左子树中所有项的值都大于X中的项。注意,这意味着该树所有的元素都可以用某种一致的方式排序。 现在给出...
  • zhang_zp2014
  • zhang_zp2014
  • 2015年08月14日 21:55
  • 925

二叉搜索树(Binary Search Trees)

二叉搜索树:每个元素都有一个唯一的值,而且所有元素的值各不相同;根节点左子树中的值比根节点的值小;根节点右子树中的值比根节点的值大;根节点的左右子树也都是二叉搜索树。 带索引的二叉搜索树(inde...
  • BlueCloudMatrix
  • BlueCloudMatrix
  • 2014年03月25日 20:09
  • 1594

二叉搜索树(Binary Search Trees)小结

二叉搜索树 什么是搜索树?        用树结构来维护一个集合,该集合支持的主要操作包括:查找、插入和删除。        典型应用:字典,优先队列。 什么是二叉搜索树?     ...
  • u014328804
  • u014328804
  • 2017年05月26日 21:41
  • 139
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:Middle-题目12:96. Unique Binary Search Trees
举报原因:
原因补充:

(最多只允许输入30个字)