Why does append overwrite the list?(为什么追加会覆盖列表?)
问题描述
我在尝试HackerRank的一些问题时遇到了这个问题 https://www.hackerrank.com/challenges/list-comprehensions/problem我尝试了此解决方案
虽然SL有正确的解决方案,但由于某些原因,我不能将SL附加到主列表L,而且很明显,L。append(SL)每次执行时都会覆盖列表L,因为它打印SL的最后一个值。 为什么会这样呢? 我尝试使用Extended,但是没有将其创建为列表列表,而是将其创建为整数列表。 编辑:谢谢大家的解释!
推荐答案
您的代码确实不能工作,这是由于SL[:] = []
行:它更改了SL
引用的列表的内容。通过这样做,您可以更改L
的所有元素,因为您总是在循环中将SL
引用的列表追加到L
。替换为SL = []
将解决此问题,因为在这种情况下,您将创建一个新列表,而不覆盖以前的列表。
它可以是固定的,也可以更具可读性,更易于调试(如果需要),建议如下:
当x=1,y=2,z=3,n=4时:输出如下:
这篇关于为什么追加会覆盖列表?的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!