今天在学python的时候遇到一个问题,循环一个数组 指定一个数,如果数组内有相同的元素就删除。
1. 前提是不能新增内存,就在该数组内处理
1
2
3
4
5
6
7
|
nums = [ 0 , 1 , 2 , 2 , 3 , 0 , 4 , 2 ]
val = 2
for i in nums:
if (i = = val):
idx = nums.index(i)
nums.pop(idx)
print (nums)
|
一开始写成这样时候输出
[0, 1, 2, 3, 0, 4] //中间的2居然没有删除
然后我修改了一下 把每一次循环都打出来看看
1
2
3
4
5
6
7
|
0loop [ 0 , 1 , 2 , 2 , 3 , 0 , 4 , 2 ]
1loop [ 0 , 1 , 2 , 2 , 3 , 0 , 4 , 2 ]
2loop [ 0 , 1 , 2 , 3 , 0 , 4 , 2 ] / / 这里被跳过了
3loop [ 0 , 1 , 2 , 3 , 0 , 4 , 2 ]
4loop [ 0 , 1 , 2 , 3 , 0 , 4 , 2 ]
5loop [ 0 , 1 , 2 , 3 , 0 , 4 , 2 ]
6loop [ 0 , 1 , 2 , 3 , 0 , 4 ]
|
原因是因为python中for循环用迭代器实现,而pop方法删除了当前元素后,被删除的位置由后面的填补,而循环自动指到下一个元素,也就相当于那个2被跳过了。
网上搜的一些处理方法 比较适合这个的是用
1
2
3
4
|
for i in nums[:]: / / 在这里nums[:]相当于复制了一份,但是并不是同一份。
if (i = = val):
idx = nums.index(i)
nums.pop(idx)
|
输出
[0, 1, 3, 0, 4]
补充知识:python 中for循环(continue, break, pass)用法
1、continue 跳过当前继续执行下一个循环
1
2
3
4
5
|
l = [ 'a' , 'b' , 'c' , 'd' , 'e' ]
for i in l: #i遍历l列表中的每一个元素
if i = = 'c' :
continue #continue以下的代码不执行直接进入下一个循环
print (i)
|
2、break 直接中断循环,不再执行
1
2
3
4
5
|
l = [ 'a' , 'b' , 'c' , 'd' , 'e' ]
for i in l:
if i = = 'c' :
break #break直接跳出循环,break以下代码全部不执行
print (i)
|
3、pass 什么都不操作,接着循环
1
2
3
4
5
|
l = [ 'a' , 'b' , 'c' , 'd' , 'e' ]
for i in l: #i遍历l列表中的每一个元素
if i = = 'c' :
pass
print (i)
|
以上为个人经验,希望能给大家一个参考,也希望大家多多支持服务器之家。如有错误或未考虑完全的地方欢迎留言讨论,望不吝赐教。
原文链接:https://blog.csdn.net/m0_37672495/article/details/105810053