1、在列表循环中对列表元素进行删除操作,会不会出错?
解答:结果不正确。例子:
原因是:因为删除元素后,整个列表的元素会往前移动,指针是不断增大的。for循环实际是循环的列表下标(索引),同时由于列表的可变性,每一次删除一个元素,列表的长度就会发生变化,元素的索引也会发生变化(List的Remove方法在删除元素的时候总会保持下标连续。例如,删掉第一个元素的时候,后面的元素会依次往前覆盖)。例如上题:
第一次循环,循环索引为0,刚开始指针指向列表的第一个元素即a[0]=1,判断后直接删除该元素,此时列表a= [2, 3, 4, 5, 6, 7, 8],
第二次循环,循环索引为1,指针指向第二个元素a[1]=3, 判断后直接删除该元素,此时列表a= [2, 4, 5, 6, 7, 8],
第三次循环,循环索引为2,指针指向第三个元素a[2]=5, 判断后直接删除该元素,此时列表a= [2, 4, 6, 7, 8],
第四次循环,循环索引为3,指针指向第四个元素a[3]=7,不满足条件
第五次循环,循环索引为4,指针指向第五个元素a[4]=8,不满足条件
循环结束!
解决方法:
1、遍历在新的列表(列表的副本)操作,删除是在原来的列表操作
或者b=a.copy() 也可以
2、因为列表总是“向前移”,所以可以倒序遍历,即使后面的元素被修改了,还没有被遍历的元素和其坐标还是保持不变的。
总结:
相似的问题,在遍历列表的循环中,如果向列表中添加元素,并且添加是在当前遍历到的元素之前,那么也会影响程序的正确执行。
a = [1,2,3,4,5]
for i in a:
if i == 3:
a.insert(1,9)
print(a)
[1, 2, 3, 4, 5]
[1, 2, 3, 4, 5]
[1, 9, 2, 3, 4, 5]
[1, 9, 9, 2, 3, 4, 5]
[1, 9, 9, 9, 2, 3, 4, 5]
[1, 9, 9, 9, 9, 2, 3, 4, 5]
[1, 9, 9, 9, 9, 9, 2, 3, 4, 5]
[1, 9, 9, 9, 9, 9, 9, 2, 3, 4, 5]
[1, 9, 9, 9, 9, 9, 9, 9, 2, 3, 4, 5]
[1, 9, 9, 9, 9, 9, 9, 9, 9, 2, 3, 4, 5]
[1, 9, 9, 9, 9, 9, 9, 9, 9, 9, 2, 3, 4, 5]
[1, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 2, 3, 4, 5]
[1, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 2, 3, 4, 5]
[1, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 2, 3, 4, 5]
[1, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 2, 3, 4, 5]
[1, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 2, 3, 4, 5]
[1, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 2, 3, 4, 5]
...
...
...
执行结果就会一直没有结尾。但是如果在当前元素之后添加元素,就不会产生错误。
a = [1,2,3,4,5]
for i in a:
if i == 3:
a.insert(4,9)
print(a)
a = [1,2,3,4,5]
for i in a:
if i == 3:
a.insert(4,9)
print(a)
a = [1,2,3,4,5]
for i in a:
if i == 3:
a.insert(4,9)
print(a)
[1, 2, 3, 4, 5]
[1, 2, 3, 4, 5]
[1, 2, 3, 4, 9, 5]
[1, 2, 3, 4, 9, 5]
[1, 2, 3, 4, 9, 5]
[1, 2, 3, 4, 9, 5]
所以对于原问题,如果是在当前元素的后面删除一个元素,那也是不会影响正确结果的。