python中用remove()为什么删除不干净列表中的多个相同元素

python中用remove()为什么删除不干净列表中的多个相同元素

如题:
要删除num_list列表中所有的 3 。

第一种情况,相同的元素不是连续的:
num_list = [1, 3, 5, 3, 2]

我可能会这么敲:

for i in num_list:
    if i == 3:
        num_list.remove(i)
print(num_list)

运行结果为: [1, 5, 2]
确实删掉了列表里所以的 3 。

第二种情况,相同的元素有连续的
num_list = [1, 3, 3, 3, 5, 3, 2]

我们在用刚才的代码测试,运行结果却是: [1, 5, 3, 2]

那为什么用remove()会删不干净呢?

在该题中因为for循环语句是按照该列表元素的下标进行取数,并不会因为添加了元素或者删除了元素而所影响。
而在python中,对列表进行增删元素之后,会对其他元素进行相应移动。
其次就是要理解remove()函数,它是对第一个出现的指定数据进行删除操作,删除之后,对剩余元素进行自动移位。
上题分析(执行原理):
当执行第一次循环时,下标为 0 ;i == 1,if 判断条件不满足,进入下一次循环,此时列表为:[1, 3, 3, 3, 5, 3, 2]
当执行第二次循环时,下标为 1 ;i == 3,if 判断条件满足,删除列表中出现的第一个 3 ,此时列表为:[1, 3, 3, 5, 3, 2],其他元素下标同时往前移动
当执行第三次循环时,下标为 2 ;i == 3,if 判断条件满足,删除列表中出现的第一个 3 ,此时列表为:[1, 3, 5, 3, 2]
这要提醒的是:
执行第三次循环时,下标为 2 对应的 3 ,是此时列表[1, 3, 3, 5, 3, 2]中的第3个数,而将删除的 3 是列表[1, 3, 3, 5, 3, 2]中的的第2个 3 。所以这就出现了错删
当执行第四次循环时,下标为 3 ;i == 3,if 判断条件满足,删除列表中出现的第一个 3 ,此时列表为:[1, 5, 3, 2],同理:是错删
当执行第五次循环时,下标为 4 ;i == 2,if 判断条件不满足,进入下一次循环,此时列表为:[1, 5, 3, 2]
当执行第六次,执行前判断列表元素走完了,打印列表num_list。此时列表 为[1, 5, 3, 2]
因此会删不干净(漏删)!

解决办法:

第一种:

#将 遍历元素 和 删除元素 分开进行
del_list = []  # 用来记录 要删除的元素
for num in num_list:
    if num == 3:
        # 本次记录筛选出的元素,不进行删除。
        # 并将筛选出的元素添加到列表del_list 中。
        del_list.append(num)
for del_num in del_list:
    # 从列表del_list中的遍历每一个元素del_num,
    # 到列表num_list中进行删除相应的元素
    num_list.remove(del_num)
print(num_list)

第二种:

# 先获取列表num_list 的长度
a = len(num_list)
# print(a)
# 第一个参数"a-1":起始;第二个参数"-1":终止;
# 也就是说,下角标从0开始计数,而长度计数是从1开始,所以,第一个参数和第二个参数各自减一。
# 第三个参数"-1":为 步长,也就是说每隔"-1"个输出一个数,由于第一、二参数导致倒序输出,所以步长,需改为负数。
# 倒序遍历列表中的元素。
for i in range(a-1, -1, -1):
    # print(i)
    # num_list[i]为列表里的每一个元素,当该元素等于 3 时
    # 就删除num_list列表中第一个出现的指定数据 3 ,
    # 遍历一遍之后,因(倒序输出,下一个序号)==(删除一个元素后,下角标长度-1);正好相等,互不影响,
    # 实现了从后往前遍历,从前往后删除。
    if num_list[i] == 3:
        num_list.remove(3)
print(num_list)

两种方法的运行结果都为:[1, 5, 2] ,成功删除列表中所有的 3 。

 以上是结合老师的讲解和自己的理解归纳写的!

ps:第一次写博客,有理解错误的,或者写得不好的地方,希望大大能大方指出来,我将会虚心接受,并改正,谢谢。

  • 38
    点赞
  • 72
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 12
    评论
### 回答1: 可以使用列表推导式和 set() 函数来删除数组多个相同元素。具体代码如下: ```python arr = [1, 2, 3, 2, 4, 3, 5, 6, 5] arr = list(set([i for i in arr])) print(arr) ``` 输出结果为:[1, 2, 3, 4, 5, 6] ### 回答2: 在Python,可以使用列表推导式或集合(set)来删除数组多个相同元素。 1. 使用列表推导式: 列表推导式是一种构建新列表的方法,可以通过遍历原始数组,并使用条件判断来选择要保留的元素,从而实现删除重复元素的效果。 例如,假设原始数组为arr,要删除元素为value,可以使用以下代码进行删除操作: ```python arr = [1, 2, 3, 2, 4, 3, 5] value = 2 new_arr = [x for x in arr if x != value] ``` 这段代码会生成一个新的列表new_arr,其排除了与value相等的元素。输出结果为[1, 3, 4, 3, 5]。 2. 使用集合(set): 集合是一种无序且唯一的对象集合,可以利用这个特性来删除数组的重复元素。将数组转换为集合,然后再转换回列表即可。 例如,假设原始数组为arr,可以使用以下代码进行删除操作: ```python arr = [1, 2, 3, 2, 4, 3, 5] new_arr = list(set(arr)) ``` 上述代码会首先将arr转换为集合,然后再转换为列表。输出结果为[1, 2, 3, 4, 5]。 需要注意的是,上述方法会打乱元素的原始顺序,如果要保持顺序不变,可以使用有序集合来进行操作,例如使用collections模块的OrderedDict()函数。 综上所述,可以使用列表推导式或集合来删除数组多个相同元素。 ### 回答3: 在Python,可以使用循环结合删除方法来删除数组多个相同元素。下面是一个示例代码: ```python def remove_duplicates(arr): # 用一个空列表来存储去重后的元素 result = [] # 遍历数组的每一个元素 for elem in arr: # 如果元素不在结果列表,则将其添加到结果列表 if elem not in result: result.append(elem) return result # 示例用法 my_array = [1, 2, 3, 4, 3, 2, 1, 5, 6, 5, 4] result_array = remove_duplicates(my_array) print(result_array) ``` 运行结果为: ``` [1, 2, 3, 4, 5, 6] ``` 在上述代码,`remove_duplicates`函数接受一个数组作为输入,并返回一个去重后的新数组。它通过遍历输入数组的每一个元素,判断该元素是否已经存在于结果列表,若不存在则将该元素添加到结果列表。最后,函数返回结果列表。 需要注意的是,这种方法删除的是连续出现的相同元素,如果需要删除所有相同元素,可以使用`collections.Counter`模块来完成。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 12
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

CodeBoy‍

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值