程序跳过列表元素

时间:2018-09-16 12:03:30

标签: python python-3.x

我正在尝试编写一个程序来跟踪(示例)细胞集落如何生长。 很简单;

  • 单元格从0岁开始
  • 在1岁时,成年人能够繁殖,每年制造1个细胞(缓慢,我知道)
  • m细胞死亡的年龄
  • 我们想要n年后的细胞数量 例如:n = 6,m = 3,结果是4个单元格

我试图通过创建两个列表来解决此问题:

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],它将仅移除两个单元格中的一个,而将另一个单元格留在此处。随着时间的流逝,这些积聚起来,最终您会得到一个充满成人的婴儿清单...

自从我开始编程以来,我从未遇到过这种困扰。我可能忽略了一些简单的事情,但仍然需要帮助!

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]