dfs, 退出条件为 总数超过 k 或者总和超过 n

#
# 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可
#
# 
# @param k int整型 
# @param n int整型 
# @return int整型二维数组
#
class Solution:
    def combination(self , k: int, n: int) -> List[List[int]]:
        # write code here
        res = []
        def dfs(s, t):
            nonlocal res
            if sum(t) > n or len(t) > k:
                return
            if sum(t) == n and  len(t) == k:
                res.append(list(t))
                return
            for i in range(s, 10):
                dfs(i + 1, t + [i])
        dfs(1, [])
        return res