1.题目描述
给定一组不含重复元素的整数数组 nums,返回该数组所有可能的子集(幂集)。
说明:解集不能包含重复的子集。
示例:
输入: nums = [1,2,3]
输出:
[
[3],
[1],
[2],
[1,2,3],
[1,3],
[2,3],
[1,2],
[]
]
2.思路
假如初始输入列表为[1],那么全部子集为subset1 = [[], [1]],当输入[1, 2],比之前多输入了一个,那么其多出来的子集为 [] + [2] = [2], [1] + [2] = [1, 2];以此推理可得出:每加入一个元素后的列表的全部子集,等于之前列表的全子集中的各子集加上该元素组成的新的子集的集合
3.代码
class Solution(object):
def subsets(</