Leetcode之回溯法专题-78. 子集(Subsets)
Leetcode之回溯法专题-78. 子集(Subsets)
给定一组不含重复元素的整数数组 nums,返回该数组所有可能的子集(幂集)。
说明:解集不能包含重复的子集。
示例:
输入: nums = [1,2,3] 输出: [ [3], [1], [2], [1,2,3], [1,3], [2,3], [1,2], [] ]
分析:
这题也是很基础的关于回溯法的一题,题中给一个数组,求他的子集(包括空集)。
AC代码:
class Solution { List<List<Integer>> ans = new ArrayList<>(); public List<List<Integer>> subsets(int[] nums) { int[] vis = new int[nums.length]; dfs(nums,new ArrayList<Integer>(),0); return ans; } public void dfs(int nums[],ArrayList<Integer> list,int step){ if(step==nums.length){ ans.add(new ArrayList<>(list)); return; } list.add(nums[step]); dfs(nums,list,step+1); list.remove(list.size()-1); dfs(nums,list,step+1); } }
作者:秦羽纶
本文版权归作者所有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文链接,否则保留追究法律责任的权利.