Problem 78: Subsets
思路
复杂度
public class Solution {
public List<List<Integer>> subsets(int[] nums) {
List<Integer> path = new ArrayList<Integer>();
List<List<Integer>> rst = new ArrayList(path);
if (nums == null || nums.length == 0) {
return rst;
}
// 这道题里是否 sort 数组不重要
// Arrays.sort(nums);
helper(nums, path, 0, rst);
return rst;
}
private void helper(int[] nums, List<Integer> path, int pos, List<List<Integer>> rst) {
rst.add(new ArrayList(path));
for (int i = pos; i < nums.length; i++) {
path.add(nums[i]);
helper(nums, path, i + 1, rst);
path.remove(path.size() - 1);
}
}
}易错点
补充
Last updated