[问题] append(element+[])

楼主: typhoonss821 (jeff)   2018-07-05 10:33:29
大家好
最近在刷leetcode 写到一题给出一组数列 求所有permutations的可能
https://leetcode.com/problems/permutations/description/
我的code是这样的,主体无穷递回的方式求解
class Solution:
def getSolution(self, x):
cach = []
result = []
self.permutations(x, cach, result)
return result
def permutations(self, x, cach, result):
if len(x) == 0:
result.append(cach)
for i in range(len(x)):
cach.append(x[i])
self.permutations(x[:i]+x[i+1:], cach, result)
cach.pop()
但我发现在上色部分append完的result在下一次append前他的值都会自动被改变
而我google了使用一样解法的code,发现只要将append(cach)改成append(cach+[])
这样的输出就不会有值被改变的问题
我查了半天找不到类似的解释 不太知道+[]的用意是什么
所以来这边请教大家
先谢谢大家的回答了!
作者: pmove (金疾柠檬)   2018-07-05 12:52:00
原来+[]是这个意思,之前比较常见的是cach[:]
作者: handsomeLin (DoGLin)   2018-07-05 23:02:00
因为你塞同一个reference进去 在result里的结果会都一样 相当于copy没错
楼主: typhoonss821 (jeff)   2018-07-05 12:31:00
非常感谢两位的回答
作者: Yshuan (倚絃)   2018-07-05 11:23:00
是function的mutable arguments特性 建议避免必须用的话, 最安全就是caller或callee去做copy
作者: mikapauli (桜花)   2018-07-05 10:41:00
复制的意思,或是用cach.copy()、cach[:]、list(cach)、tuple(cach)等都可以。
楼主: typhoonss821 (jeff)   2018-07-05 10:51:00
请问是因为list的mutable性质所以改变cach也会改变之前的result.append吗?

Links booklink

Contact Us: admin [ a t ] ucptt.com