leetcode-----给定一个值n,请生成所有的存储值1...n.的二叉搜索树(BST)的结。.例如: 给定n=3,你的程序应该给出下面五种不同的二叉搜索树(BST)

题目描述

给定一个值n,请生成所有的存储值1...n.的二叉搜索树(BST)的结构

例如:

给定n=3,你的程序应该给出下面五种不同的二叉搜索树(BST)

   1         3     3      2      1↵           /     /      /       ↵
     3     2     1      1   3      2↵    /     /                        ↵
   2     1         2                 3

 

如果你不清楚“{1,#,2,3}"的含义的话,请继续阅读

我们用如下方法将二叉树序列化:

二叉树的序列化遵循层序遍历的原则,”#“代表该位置是一条路径的终结,下面不再存在结点。

例如:

   1↵  / ↵ 2   3↵    /↵   4↵    ↵     5

上述的二叉树序列化的结果是:"{1,2,3,#,#,4,#,#,5}".

//二叉搜索树(二叉排序树):左<根<右
    public ArrayList<TreeNode> generateTrees (int n) {
         return getTrees(1,n);
    }
    //生成[min,max]范围内的随机数
    
    public ArrayList<TreeNode> getTrees(int min,int max){
        final ArrayList<TreeNode> trees = new ArrayList<TreeNode>();//存放二叉搜索树集合
        if(min>max){//空树
            trees.add(null);
            return trees;
        }
        if(min==max){//只有根节点,值为min
            TreeNode r = new TreeNode(min);
            trees.add(r);
            return trees;
        }
        for(int i=min;i<=max;i++){//对于根节点取[min,max]范围内不同的值时,可能生成的二叉搜索树
            ArrayList<TreeNode> left = getTrees(min,i-1); //当根节点为i时,可生成不同左子树的个数
            ArrayList<TreeNode> right = getTrees(i+1,max);//当根节点为i时,可生成不同右子树的个数
            for(int l=0;l<left.size();l++){//针对不同的情况,一共可生成不同 BST的个数
                for(int r=0;r<right.size();r++){
                    TreeNode root = new TreeNode(i);
                    root.left = left.get(l);
                    root.right = right.get(r);
                    trees.add(root);
                }//for
            }//for
        }//for
        return trees;
    }

 

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值