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

leetcode96 Unique Binary Search Trees

时间:2016-06-03 17:25:14      阅读:192      评论:0      收藏:0      [点我收藏+]

标签:

题目:

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.

技术分享

思路:

需要使用递推关系来解决。

对于n个结点,除去根节点,还剩余n-1个结点。

因此左右子树的结点数分配方式如下所示:

(0,n-1), (1,n-2), (2, n-3), ....(n-1,0)

我们可以简单的得到:

n=0时,种类数为num(n)=1;

n=1时,种类数为num(n)=1;

则可以依次计算得到n个结点时二叉树的种类。

即:

num(n)=num(0)*num(n-1)+num(1)*num(n-2)+num(2)*num(n-3)+...+num(n-1)*num(0)

代码:

实现时引入了HashMap,方便记录。

    public  int numTrees(int n){
        if( n == 0 || n == 1){
            return 1;
        }
        HashMap<Integer,Integer> hm = new HashMap<Integer,Integer>();
        hm.put(0, 1);
        hm.put(1, 1);
        for(int i = 2; i <= n; i++){
            int num = 0;
            for(int j = 0; j < i; j++){
                num += hm.get(j)*hm.get(i-j-1);
            }
            hm.put(i, num);
        }
        return hm.get(n);
    }

技术分享

leetcode96 Unique Binary Search Trees

标签:

原文地址:http://www.cnblogs.com/bywallance/p/5556904.html

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