题目大意
求在1到n个数中挑选k个数的所有的组合类型。
解题思路
DFS(回溯法)
代码
DFS
和排列蛮像的,只不过到了k个数就停止递归了
class Solution(object):
def combine(self, n, k):
""" :type n: int :type k: int :rtype: List[List[int]] """
def dfs(start, valuelist):
if self.count == k:
ret.append(valuelist)
return
for i in range(start, n + 1):
self.count += 1
dfs(i + 1, valuelist + [i])
self.count -= 1
ret = []
self.count = 0
dfs(1, [])
return ret
直接用数字做
看图,摆明了不让我们这么做么,这最后一个数据集坑死了多少人。
class Solution(object):
def combine(self, n, k):
""" :type n: int :type k: int :rtype: List[List[int]] """
self.result = []
temp = []
self.combineHelper(n, k, 0, 1, temp)
return self.result
def combineHelper(self, n, k, length, num_now, temp):
# print 'start', temp, list_num, length, self.k
if length == k:
# print 'add', temp
self.result.append(temp[:]) # 这里直接写temp,就会导致result内的temp永远是一个实例,后面修改temp会使得result一直在变化
# print 'result', self.result
return
for i in range(num_now, n+1):
temp.append(i)
self.combineHelper(n, k, length+1, i+1, temp)
temp.pop()
转为list做
最后一个测试集TLE
class Solution(object):
def combine(self, n, k):
""" :type n: int :type k: int :rtype: List[List[int]] """
self.k = k
self.result = []
list_num = [i for i in range(1, n+1)]
self.combineHelper(0, [], list_num)
return self.result
def combineHelper(self, length, temp, list_num):
# print 'start', temp, list_num, length, self.k
if length == self.k:
# print 'add', temp
self.result.append(temp[:]) # 这里直接写temp,就会导致result内的temp永远是一个实例,后面修改temp会使得result一直在变化
# print 'result', self.result
return
for i, num in enumerate(list_num):
temp.append(num)
# print temp, list_num[i+1:]
# print '-------'
self.combineHelper(length+1, temp, list_num[i+1:])
temp.pop()
总结
做DFS时,有很多小细节,比如该题,temp需要pop,不能在上面加入result那里做,应该是在调用递归后做。
此题肯定有非递归写法,有空琢磨。