我正在尝试制作一个程序来跟踪(示例)细胞集落如何生长。 非常简单;
- 细胞从 0 岁开始
- 1 岁时,细胞就能够繁殖,每年产生 1 个细胞(我知道,速度很慢)
- m细胞在年龄时死亡
- 我们想要 n 年后的细胞数量 示例:n = 6 且 m = 3 产生 4 个单元格
我尝试通过创建两个列表来解决这个问题:
babies = [0] (one starting cell)
adults = []
我的计划是在婴儿一岁后将每个baby_cell移至成人列表,这也是问题所在。这是我写的:
index = 0
for baby in babies:
if baby == 1:
adults.append(baby)
del babies[index]
index += 1
它只移动一个单元格,因此如果babys = [1, 1],它只会删除两个单元格中的一个,并将另一个保留在那里。随着时间的推移,这些积累起来,最终你会得到一张充满成人的婴儿名单......
自从我开始编程以来,我从来没有这么陷入过困境。我可能忽略了一些简单的事情,但我仍然需要帮助!
最佳答案
dupe: How to remove items from a list while iterating 中介绍了它不起作用的原因。 - 该错误源于编辑您此时正在迭代的同一列表。
<小时/>相反,您可以使用列表推导式(和一个列表)来模拟这一点:
cells = [0]
adult = 1
death = 3
simulateTime = 6
print(f"Time 0: {cells}")
for t in range(simulateTime):
# advance age, die if too old - use < death if age 3 should not breed anymore
cells[:] = [x+1 for x in cells if x+1 <= death]
# breed adult ones
cells.extend( (0 for x in cells if x >= adult) )
print(f"Time {t+1}: {cells}")
输出:
Time 0: [0]
Time 1: [1, 0]
Time 2: [2, 1, 0, 0]
Time 3: [3, 2, 1, 1, 0, 0, 0, 0]
Time 4: [3, 2, 2, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0]
Time 5: [3, 3, 2, 2, 2, 2, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0]
Time 6: [3, 3, 3, 3, 2, 2, 2, 2, 2, 2, 2, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0]
我似乎错过了一些标准,就像在 3 岁和 6 岁迭代中死亡一样,我得到的细胞远远超过 4 个;o)。
与 x+1 < death
的列表比较结果:
Time 0: [0]
Time 1: [1, 0]
Time 2: [2, 1, 0, 0]
Time 3: [2, 1, 1, 0, 0, 0]
Time 4: [2, 2, 1, 1, 1, 0, 0, 0, 0, 0]
Time 5: [2, 2, 2, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0]
Time 6: [2, 2, 2, 2, 2, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0]
关于python - 程序跳过列表元素,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/52353943/