40. Combination Sum II
data:image/s3,"s3://crabby-images/d34e4/d34e41fde25a8e21006314bc60fedc1de4a004e9" alt="Tapan Rachchh"
1 min read
data:image/s3,"s3://crabby-images/4ebed/4ebedd85c142d0b1dfce071c06c2dcec0cb0e1ae" alt=""
class Solution:
def combinationSum2(self, candidates: List[int], target: int) -> List[List[int]]:
candidates.sort()
N = len(candidates)
ans = set()
def checker(currentSum, nextIndex, nums):
if currentSum == target:
t = tuple(nums)
if t not in ans:
ans.add(t)
return
if nextIndex >= N or currentSum > target:
return
for i in range(nextIndex, N):
if i > nextIndex and candidates[i] == candidates[i - 1]:
continue
checker(currentSum + candidates[i], i + 1, nums + [candidates[i]])
checker(0, 0, [])
return ans
0
Subscribe to my newsletter
Read articles from Tapan Rachchh directly inside your inbox. Subscribe to the newsletter, and don't miss out.
Written by
data:image/s3,"s3://crabby-images/d34e4/d34e41fde25a8e21006314bc60fedc1de4a004e9" alt="Tapan Rachchh"