目录
引入
话不多说,先来一道面试题练练手。
a=[1,2,3,4,5]
for i in a:
a.remove(i)
print(a)
各位看官猜一猜结果是几?
我掐指一算: 回复空列表[]的朋友不在少数吧,但是,魔鬼往往隐藏在结果之中,请看
结果反转
[2, 4]
原因分析
为了查看每次for循环a的变化,我们在遍历时加入print,如下
a=[1,2,3,4,5]
for i in a:
a.remove(i)
print(a)
# 输出
[2, 3, 4, 5]
[2, 4, 5]
[2, 4]
首先我们发现for循环的循环体一共执行了3次
这是为啥呢?
第 几 次遍历列表的时候, 循环变量i的值就是【当前列表】的第 几 个元素
因为Python的列表是引用类型,所以在遍历的时候可以修改列表,比如增加、删除
但无论如何,我们遍历时都是根据最新的列表,而不是最开始的列表。
拿上面的代码举例子
第几次遍历 | i | 删除i之后列表a |
1 | 1 | [2,3,4,5] |
2 | 3 | [2,4,5] |
3 | 5 | [2,4] |
之所以第2次遍历的时候i是3,如下图
然后当i为5的时候也就是列表的最后一个元素了,所以它也被删除了
最终结果是 [2,4]
小测试
看看你到底学会了吗?做做下面的题吧
下面的代码本来是想把列表a里面的1全部删除,没有1就break退出
但真能实现这样的效果吗,各位看官可以自己想一想哈
a = [1,2,1,1,3,1]
for i in a:
if 1 not in a:
break
a.remove(1)
print(a)
!!!先不要看下面的解析
!!!先不要看下面的解析
!!!先不要看下面的解析
第几次遍历 | i | 删除i之后列表a |
1 | 1 | [2,1,1,3,1] |
2 | 1 | [2,1,3,1] |
3 | 3 | [2,3,1] |
因为第3次遍历后列表只有3个元素,所以不会进行第4次遍历。
好的,到此为止问题解决啦。
参考文章
Python列表的remove方法的注意事项
python for循环列表remove操作
欢迎各位看官和我交流~