python的生成器和列表的一个小坑(生成器可修改)

本文通过解决LeetCode问题1089,探讨了在Python中使用生成器代替列表节省空间时遇到的意料之外的情况。原本期望生成器在列表修改后仍能正确工作,但结果出乎意料。经过分析,发现生成器在遍历过程中如果列表被修改,会影响后续的__next__()调用,导致生成器行为不一致。结论是理解生成器的工作原理至关重要,尤其是在涉及对迭代对象的修改时。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

由来

没事刷leecode,有一个1089题,讲的是在一个列表中,我们需要在每一个0后面插入一个0,并且保证列表总长度不变。
那么我就用一个列表将所有需要插入的地方存起来,然后在对应位置插入即可:

def duplicateZeros(arr):
    n = len(arr)
    zero = [i for i in range(n) if not arr[i]]
    for i,num in enumerate(zero):
        if i+num+1 >= n:
            
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值