forked from aylei/leetcode-rust
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathn0095_unique_binary_search_trees_ii.rs
83 lines (75 loc) · 1.77 KB
/
n0095_unique_binary_search_trees_ii.rs
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
/**
* [95] Unique Binary Search Trees II
*
* Given an integer n, generate all structurally unique BST's (binary search trees) that store values 1 ... n.
*
* Example:
*
*
* Input: 3
* Output:
* [
* [1,null,3,2],
* [3,2,null,1],
* [3,1,null,null,2],
* [2,1,3],
* [1,null,2,null,3]
* ]
* Explanation:
* The above output corresponds to the 5 unique BST's shown below:
*
* 1 3 3 2 1
* \ / / / \ \
* 3 2 1 1 3 2
* / / \ \
* 2 1 2 3
*
*/
pub struct Solution {}
// submission codes start here
/*
1
1 2
\ /
2 1
1 3 3 2 1
\ / / / \ \
3 2 1 1 3 2
/ / \ \
2 1 2 3
4 1
/ \
(5*) 3
/ \
2 4
*/
use super::util::tree::{TreeNode, to_tree};
use std::rc::Rc;
use std::cell::RefCell;
impl Solution {
pub fn generate_trees(n: i32) -> Vec<Option<Rc<RefCell<TreeNode>>>> {
if n < 1 {
return vec![];
}
let mut res = vec![Some(Rc::new(RefCell::new(TreeNode::new(1))))];
for val in 2..n+1 {
let mut next = Vec::new();
for root in res.into_iter() {
let mut dummy = Some(Rc::new(RefCell::new(TreeNode{val: 0, left: None, right: None})));
let mut parent = dummy.as_ref().unwrap().clone();
let mut node = root;
// we know that val is larger than all the elements in the tree
}
res = next;
}
res
}
}
// submission codes end
#[cfg(test)]
mod tests {
use super::*;
#[test]
fn test_95() {
}
}