CODE

class Solution:
    def subsets(self, nums: List[int]) -> List[List[int]]:
        res = []
        
        subset = []
        def backtrack(i):
            if i >= len(nums):
                res.append(subset.copy())
                return
            # decision to include nums[i]
            subset.append(nums[i])
            backtrack(i + 1)
            # decision NOT to include nums[i]
            subset.pop()
            backtrack(i + 1)
        
        backtrack(0)
        return res
        

Last updated