用pop函数连续删除列表元素
for l in range(0,len(lists)-1):
if lists[l]==lists[l+1]:
lists[l-1].pop()
Python中用pop函数连续删除列表元素
- 写回答
- 好问题 0 提建议
- 追加酬金
- 关注问题
- 邀请回答
-
3条回答 默认 最新
- CSDN专家-天际的海浪 2022-04-03 20:49关注
因为移除了一个元素之后其后面元素的索引值都会减一,列表长度也会减一。
但循环索引只会加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)
如有帮助,请点击我的回答下方的【采纳该答案】按钮帮忙采纳下,谢谢!
本回答被题主选为最佳回答 , 对您是否有帮助呢?解决 1无用
悬赏问题
- ¥15 随身WiFi网络灯亮但是没有网络,如何解决?
- ¥15 gdf格式的脑电数据如何处理matlab
- ¥20 重新写的代码替换了之后运行hbuliderx就这样了
- ¥100 监控抖音用户作品更新可以微信公众号提醒
- ¥15 UE5 如何可以不渲染HDRIBackdrop背景
- ¥70 2048小游戏毕设项目
- ¥20 mysql架构,按照姓名分表
- ¥15 MATLAB实现区间[a,b]上的Gauss-Legendre积分
- ¥15 delphi webbrowser组件网页下拉菜单自动选择问题
- ¥15 linux驱动,linux应用,多线程