如何解决如何获得包含迭代的10个最新值的列表?
我想要一个包含for
循环中计算出的十个最新值的列表。
我试图删除列表中的i - 10
元素,然后附加在i'th
迭代中计算出的值。这是我尝试过的:
points = []
x = 0
for i in range(1000):
x += 1
if i > 9: # to check when to start removing the first element
del points[i - 10]
points.append(i * x * (1 - x)) # appending the value calculating
else:
points.append(i * x * (1 - x))
但是,出现此错误:
Traceback (most recent call last):
File "*******.py",line 9,in <module>
del points[i - 10]
IndexError: list assignment index out of range
我不确定为什么会这样,因为清单足够长,条件确定。 谢谢您的任何建议。
解决方法
您的列表的长度永远不会超过10个元素,因为一旦长度达到10,您就开始删除第一个元素,然后再添加一个元素。因此,当i
大于19时,索引i - 10
不在列表的范围内。
您总是添加到列表的末尾,并且从逻辑上讲,只希望删除 first 元素。因此,将del points[i - 10]
替换为del points[0]
:
points = []
x = 0
for i in range(1000):
x += 1
if i > 9: # to check when to start removing the first element
del points[0]
points.append(i * x * (1 - x)) # appending the value calculating
else:
points.append(i * x * (1 - x))
,
您可以先创建一个长度为10的列表,然后在索引之间循环。要提取值,您必须从index + 1
到末尾再从起始到index
(其中index
是点列表的当前索引,即{ {1}}。
这将比修改列表更加有效,因为删除列表的第一个元素的时间复杂度为O(n)。
i % 10
如果您希望不带points = [None] * 10
for i in range(1000):
x = i + 1 # This seems to be the same as your x.
value = i * x * (1 - x)
index = i % 10
points[index] = value
# Do this whenever you want to print
index = (index + 1) % 10
print('Recent values:',points[index:] + points[:index])
的输出打开,并且将元素从最新到最旧排序,则可以这样打印:
None
,
请考虑一下,当i
为100时会发生什么:您正试图删除points[90]
中的元素,但是列表的长度仅为10,因此超出范围错误。确实,您每次都想删除列表的第一个元素。因此该行应显示为del points[0]
。
但是,一种更有效的方法是使用slicing来确保列表长度不超过10:
points = []
for i in range(1000):
x = i+1
points.append(i * x * (1 - x))
points = points[-10:]
points[-10:]
从列表中倒数第10个元素中选择所有元素。
当然,您的索引超出了范围!您在列表中仅保留10个项目,但是i
的范围最大为999!如果列表中只有10个项目,您如何想象可以为项目998 - 10
编制索引?
您需要将其想象为一个队列:一个数据结构,您可以在其中删除项目的开头并将其添加到末尾。实际上,Collections
包具有这样的数据结构。但是,出于您自己的目的,只需按照您的所说的操作去做即可:摆脱最古老的物品:
if i > 9: # to check when to start removing the first element
points.pop(0)
points.append(i * x * (1 - x))
请注意,我已经重构了您的新元素:您在if
的每个分支中执行相同的操作,因此没有必要复制代码。
您最后的points
是
[-971279100,-974224352,-977175552,-980132706,-983095820,-986064900,-989039952,-992020982,-995007996,-998001000]
,
将del points[i - 10]
更改为del points[0]
,因为当我达到20时,它将尝试删除不存在的索引10。因此,只需将其更改为0。
这就是您想要的:
points = []
x = 0
for i in range(1000):
x += 1
if i > 9: # to check when to start removing the first element
del points[0]
points.append(i * x * (1 - x)) # appending the value calculating
else:
points.append(i * x * (1 - x))
之所以可行,是因为一旦您在列表中找到10个元素,一次只会添加一个元素,并且您将始终删除列表的第一个元素,即points [0]
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。