python 子列表合并谜团:未赋值,值却改变
你提到在 python 代码中,你想要将具有相同前两个字符的子列表合并,并将最后一个值相加,放入一个新的列表中。虽然你没有明确给 l 列表赋值,但你可能会疑惑为什么其值也会发生变化。
原因在于 python 中列表是可变的。当你使用循环迭代 l 列表时,你在实际操作它的元素。这意味着,即使你没有给 l 重新赋值,你对元素进行的任何修改都会反映在原始列表中。
在你提供的代码中,你使用以下代码段:
if flag: l.append(l[i]) else: l[z][-1] = l[z][-1] + l[i][-1]
第一个 if 语句检查子列表是否需要追加到 l中。如果没有需要追加,则会执行第二个 else 语句。在这个语句中,你正在对 l 中特定子列表的最后一个元素进行修改,即 l[z][-1] += l[i][-1]。
由于 l 和 l 都是在同一个内存位置,因此对 l 中子列表的修改也会影响 l 中的对应子列表。这就是为什么 l 中的值也在发生变化的原因。
为了解决这个问题,可以将 l[i] 的副本添加到 l 中,如以下代码所示:
if flag: L.append(l[i][:]) else: L[z][-1] += l[i][-1]
这样,你就避免了对 l 元素的直接修改,从而不会影响原始列表。