我正试图制作一个程序来跟踪一个(例如)细胞集落将如何生长。这很简单;
我试图通过创建两个列表来解决这个问题:
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,它只会移除两个细胞中的一个,而将另一个细胞留在那里。随着时间的推移,这些积累,最终你会得到一个充满成人的婴儿名单.
自从我开始编程以来,我从来没有这么困过。我可能忽略了一些简单的东西,但我仍然需要帮助!
发布于 2018-09-16 12:26:32
它不能工作的原因在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]https://stackoverflow.com/questions/52353943
复制相似问题