forked from mengli/leetcode
-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathSubsets.java
More file actions
35 lines (32 loc) · 779 Bytes
/
Subsets.java
File metadata and controls
35 lines (32 loc) · 779 Bytes
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
Given a set of distinct integers, S, return all possible subsets.
Note:
Elements in a subset must be in non-descending order.
The solution set must not contain duplicate subsets.
For example,
If S = [1,2,3], a solution is:
[
[3],
[1],
[2],
[1,2,3],
[1,3],
[2,3],
[1,2],
[]
]
public class Solution {
public ArrayList<ArrayList<Integer>> subsets(int[] S) {
Arrays.sort(S);
ArrayList<ArrayList<Integer>> subsets = new ArrayList<ArrayList<Integer>>();
subsets.add(new ArrayList<Integer>());
for (int i = 0; i < S.length; i++) {
int size = subsets.size();
for (int j = 0; j < size; j++) {
ArrayList<Integer> subset = new ArrayList<Integer>(subsets.get(j));
subset.add(S[i]);
subsets.add(subset);
}
}
return subsets;
}
}