递归,可重复选取一个元素,由于不能有重复的数组出现,则当符合条件时,进行排序判断是否已在结果数组中
#
# 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可
#
#
# @param target int整型
# @param nums int整型一维数组
# @return int整型二维数组
#
class Solution:
def combinationCount(self , target: int, nums: List[int]) -> List[List[int]]:
# write code here
res = []
def dfs(t):
nonlocal res
if sum(t) > target:
return
if sum(t) == target and sorted(t) not in res:
res.append(sorted(t))
return
for i in range(len(nums)):
dfs(t + [nums[i]])
dfs([])
return res