-
Notifications
You must be signed in to change notification settings - Fork 18
Expand file tree
/
Copy pathSubSetIterable.java
More file actions
34 lines (29 loc) · 1.27 KB
/
SubSetIterable.java
File metadata and controls
34 lines (29 loc) · 1.27 KB
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
package org.psjava.util;
import org.psjava.ds.array.PSArray;
import org.psjava.ds.array.MutableArrayFromIterable;
import java.util.function.Predicate;
public class SubSetIterable {
public static <T> Iterable<Iterable<T>> create(final Iterable<T> superSet) {
final PSArray<T> array = MutableArrayFromIterable.create(superSet);
Assertion.ensure(array.size() <= 30, "too big set to iterate sub set");
return ConvertedIterable.create(ZeroTo.get(1 << array.size()), new Converter<Integer, Iterable<T>>() {
@Override
public Iterable<T> convert(final Integer bits) {
// Cannot get size of the sub st at this time. Because we use filter way
return ConvertedIterable.create(FilteredIterable.create(ZeroTo.get(array.size()), new Predicate<Integer>() {
@Override
public boolean test(Integer index) {
return IntBitUtil.get(bits, index);
}
}), new Converter<Integer, T>() {
@Override
public T convert(Integer index) {
return array.get(index);
}
});
}
});
}
private SubSetIterable() {
}
}