我正在尝试编写一个程序来跟踪(示例)细胞集落如何生长。 很简单;
我试图通过创建两个列表来解决此问题:
babies = [0] (one starting cell)
adults = []
我的计划是在婴儿1岁以后将每个baby_cell移至成人列表,这也是问题所在。这是我写的:
index = 0
for baby in babies:
if baby == 1:
adults.append(baby)
del babies[index]
index += 1
它仅移动一个单元格,因此,如果婴儿= [1,1],它将仅移除两个单元格中的一个,而将另一个单元格留在此处。随着时间的流逝,这些积聚起来,最终您会得到一个充满成人的婴儿清单...
自从我开始编程以来,我从未遇到过这种困扰。我可能忽略了一些简单的事情,但仍然需要帮助!
答案 0 :(得分:0)
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]