Python中用pop函数连续删除列表元素

用pop函数连续删除列表元素
for l in range(0,len(lists)-1):
if lists[l]==lists[l+1]:
lists[l-1].pop()

因为移除了一个元素之后其后面元素的索引值都会减一,列表长度也会减一。
但循环索引只会加1,不会跟着减1。这样会跳过一个元素.
比如一开始循环索引值是0,移除了索引值是0的元素之后,原来索引值为1的元素的索引值减一变成0。原来索引值为2的元素的索引值减一变成1。
下一次循环索引加1。移除索引值是1的元素(原来索引值为2的元素),原来索引值为1的元素就被跳过了。
对于一边循环一边删除的操作,可以用倒序循环。

你题目的解答代码如下:

lists = [2,3,3,4,4,4,6,6]
for l in range(len(lists)-1,0,-1):
    if lists[l]==lists[l-1]:
        lists.pop(l)
print(lists)

img

如有帮助,请点击我的回答下方的【采纳该答案】按钮帮忙采纳下,谢谢!

img

写的什么东西,乱七八糟。

您好,我是有问必答小助手,您的问题已经有小伙伴帮您解答,感谢您对有问必答的支持与关注!
PS:问答VIP年卡 【限时加赠:IT技术图书免费领】,了解详情>>> https://vip.csdn.net/askvip?utm_source=1146287632