class Solution:
def combinationSum2(self, candidates: List[int], target: int) -> List[List[int]]:
ans = []
candidates.sort()
def backtrack(curr, target, start, counter):
if target == 0:
ans.append(list(curr))
return
elif target < 0:
return
else:
for i in range(start, len(candidates)):
if i > start and candidates[i] == candidates[i -1]:
continue
curr.append(candidates[i])
counter[candidates[i]] -= 1
backtrack(curr, target - candidates[i], i + 1, counter)
counter[candidates[i]] += 1
curr.pop()
backtrack([], target, 0, Counter(candidates))
return ans