我目前正在通过递归了解排列生成。
我发现以下代码非常适合打印排列,但我似乎无法存储值:堆栈中的所有值在升级时都会丢失。
def permute_util(str, count, result, level):
if level == len(result):
print(result)
return
for i in range(len(str)):
if count[i] == 0:
continue;
result[level] = str[i]
count[i] -= 1
permute_util(str, count, result, level + 1)
count[i] += 1
permute_util(list("ABC"), [2,1,1], [None]*len("AABC"), 0)
结果:
['A', 'A', 'B', 'C']
['A', 'A', 'C', 'B']
['A', 'B', 'A', 'C']
['A', 'B', 'C', 'A']
['A', 'C', 'A', 'B']
['A', 'C', 'B', 'A']
['B', 'A', 'A', 'C']
['B', 'A', 'C', 'A']
['B', 'C', 'A', 'A']
['C', 'A', 'A', 'B']
['C', 'A', 'B', 'A']
['C', 'B', 'A', 'A']
我已尝试将结果添加到基本案例中的全局列表中,但只有最新级别才会存储,而所有其他先前的值都会被覆盖,如此
def permute_util(str, count, result, level):
global glob
if level == len(result):
**glob += [result]**
return
for i in range(len(str)):
if count[i] == 0:
continue;
result[level] = str[i]
count[i] -= 1
permute_util(str, count, result, level + 1)
count[i] += 1
permute_util(list("ABC"), [2,1,1], [None]*len("AABC"), 0)
['C', 'B', 'A', 'A']
['C', 'B', 'A', 'A']
['C', 'B', 'A', 'A']
['C', 'B', 'A', 'A']
['C', 'B', 'A', 'A']
['C', 'B', 'A', 'A']
['C', 'B', 'A', 'A']
['C', 'B', 'A', 'A']
['C', 'B', 'A', 'A']
['C', 'B', 'A', 'A']
['C', 'B', 'A', 'A']
['C', 'B', 'A', 'A']
['C', 'B', 'A', 'A']
也尝试了同样的效果:
def permute_util(str, count, result, level, lists):
global glob
if level == len(result):
return [result]
for i in range(len(str)):
if count[i] == 0:
continue;
result[level] = str[i]
count[i] -= 1
foo = permute_util(str, count, result, level + 1, lists)
lists = lists + foo
count[i] += 1
lists = []
permute_util(list("ABC"), [2,1,1], [None]*len("AABC"), 0, lists)
将所有“结果”存储在列表中的基本情况并在完成时返回它的最佳方法是什么?
答案 0 :(得分:1)
随着你的递归进展,你一遍又一遍地改变结果 你可以这样做:
def permute_util(string, count, result, level):
if level == len(result):
print(result)
res.append(tuple(result)) # stores current result as a copy in an immutable tuple
return
for i in range(len(string)):
if count[i] == 0:
continue;
result[level] = string[i]
count[i] -= 1
permute_util(string, count, result, level + 1)
count[i] += 1
if __name__ == '__main__':
res = []
permute_util(list("ABC"), [2, 1, 1], [None]*len("AABC"), 0)
print(res)
答案 1 :(得分:0)
Python将指针附加到列表而不是实际列表。因此,你所拥有的是很多指针指向结果的最终状态因此重复的值。每次添加时都尝试创建副本,如下所示:
final_ans = []
def permute_util(str, count, result, level):
if level == len(result):
final_ans.append(result[:]) # if you don't explicitly want list, try final_ans.append(''.join(result))
return
for i in range(len(str)):
if count[i] == 0:
continue;
result[level] = str[i]
count[i] -= 1
permute_util(str, count, result, level + 1)
count[i] += 1
permute_util(list("ABC"), [2,1,1], [None]*len("AABC"), 0)
for ans in final_ans:
print(ans)