-
-
Notifications
You must be signed in to change notification settings - Fork 2.4k
/
Copy pathsubset_generation.rs
116 lines (98 loc) · 2.74 KB
/
subset_generation.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
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
// list all subset combinations of n element in given set of r element.
// This is a recursive function that collects all subsets of the set of size n
// with the given set of size r.
pub fn list_subset(
set: &[i32],
n: usize,
r: usize,
index: usize,
data: &mut [i32],
i: usize,
) -> Vec<Vec<i32>> {
let mut res = Vec::new();
// Current subset is ready to be added to the list
if i == r {
let mut subset = Vec::new();
for j in data.iter().take(r) {
subset.push(*j);
}
res.push(subset);
return res;
}
// When no more elements are there to put in data[]
if index >= n {
return res;
}
// current is included, put next at next location
data[i] = set[index];
res.append(&mut list_subset(set, n, r, index + 1, data, i + 1));
// current is excluded, replace it with next (Note that
// i+1 is passed, but index is not changed)
res.append(&mut list_subset(set, n, r, index + 1, data, i));
res
}
// Test module
#[cfg(test)]
mod tests {
use super::*;
#[test]
fn test_print_subset3() {
let set = [1, 2, 3, 4, 5];
let n = set.len();
const R: usize = 3;
let mut data = [0; R];
let res = list_subset(&set, n, R, 0, &mut data, 0);
assert_eq!(
res,
vec![
vec![1, 2, 3],
vec![1, 2, 4],
vec![1, 2, 5],
vec![1, 3, 4],
vec![1, 3, 5],
vec![1, 4, 5],
vec![2, 3, 4],
vec![2, 3, 5],
vec![2, 4, 5],
vec![3, 4, 5]
]
);
}
#[test]
fn test_print_subset4() {
let set = [1, 2, 3, 4, 5];
let n = set.len();
const R: usize = 4;
let mut data = [0; R];
let res = list_subset(&set, n, R, 0, &mut data, 0);
assert_eq!(
res,
vec![
vec![1, 2, 3, 4],
vec![1, 2, 3, 5],
vec![1, 2, 4, 5],
vec![1, 3, 4, 5],
vec![2, 3, 4, 5]
]
);
}
#[test]
fn test_print_subset5() {
let set = [1, 2, 3, 4, 5];
let n = set.len();
const R: usize = 5;
let mut data = [0; R];
let res = list_subset(&set, n, R, 0, &mut data, 0);
assert_eq!(res, vec![vec![1, 2, 3, 4, 5]]);
}
#[test]
fn test_print_incorrect_subset() {
let set = [1, 2, 3, 4, 5];
let n = set.len();
const R: usize = 6;
let mut data = [0; R];
let res = list_subset(&set, n, R, 0, &mut data, 0);
let result_set: Vec<Vec<i32>> = Vec::new();
assert_eq!(res, result_set);
}
}