-
Notifications
You must be signed in to change notification settings - Fork 1.6k
/
Copy pathcombination-sum-ii.py
30 lines (26 loc) · 1.06 KB
/
combination-sum-ii.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
from __future__ import print_function
# Time: O(k * C(n, k))
# Space: O(k)
class Solution:
# @param candidates, a list of integers
# @param target, integer
# @return a list of lists of integers
def combinationSum2(self, candidates, target):
result = []
self.combinationSumRecu(sorted(candidates), result, 0, [], target)
return result
def combinationSumRecu(self, candidates, result, start, intermediate, target):
if target == 0:
result.append(list(intermediate))
prev = 0
while start < len(candidates) and candidates[start] <= target:
if prev != candidates[start]:
intermediate.append(candidates[start])
self.combinationSumRecu(candidates, result, start + 1, intermediate, target - candidates[start])
intermediate.pop()
prev = candidates[start]
start += 1
if __name__ == "__main__":
candidates, target = [10, 1, 2, 7, 6, 1, 5], 8
result = Solution().combinationSum2(candidates, target)
print(result)