Chinaunix首页 | 论坛 | 博客
  • 博客访问: 271985
  • 博文数量: 170
  • 博客积分: 0
  • 博客等级: 民兵
  • 技术积分: 1709
  • 用 户 组: 普通用户
  • 注册时间: 2014-05-06 18:01
文章分类

全部博文(170)

文章存档

2016年(11)

2015年(130)

2014年(29)

分类: Java

2015-09-26 15:18:39

//Unique Binary Search Trees II My Submissions Question Solution 
//Total Accepted: 39624 Total Submissions: 139751 Difficulty: Medium
//Given n, generate all structurally unique BST's (binary search trees) that store values 1...n.
//
//For example,
//Given n = 3, your program should return all 5 unique BST's shown below.
//
//   1         3     3      2      1
//    \       /     /      / \      \
//     3     2     1      1   3      2
//    /     /       \                 \
//   2     1         2                 3
//confused what "{1,#,2,3}" means? > read more on how binary tree is serialized on OJ.
import java.util.ArrayList;
import java.util.List;


public class UniqueBinarySearchTreesII {


public static void main(String[] args) {
// TODO Auto-generated method stub\
List<TreeNode> list=generateTrees(3);
System.out.println( list.size());

for(int i=0;i<list.size();i++)
System.out.println(list.get(i).val);
}
public static List<TreeNode> generateTrees(int n) {
   return generate(1,n);    
}
private static List<TreeNode> generate(int start, int end) {
// TODO Auto-generated method stub
List<TreeNode> result =new ArrayList<>();
if(start>end){
result.add(null);
return result;
}
for(int i=start;i<=end;i++){
List<TreeNode> left=generate(start, i-1);
List<TreeNode> right=generate(i+1, end);
for(int j=0;j<left.size();j++){
for(int k=0;k<right.size();k++){
TreeNode node=new TreeNode(i);
result.add(node);
node.left=left.get(j);
node.right=right.get(k);
}
}
}
return result;
}


}

阅读(726) | 评论(0) | 转发(0) |
0

上一篇:Restore IP Addresses

下一篇:zigzagLevelOrder

给主人留下些什么吧!~~